acdream/docs/research/decompiled/chunk_00500000.c
Erik 4d36756b91 research: full acclient.exe decompilation — 22,225 functions, 688K lines
Complete decompilation of the retail Asheron's Call client using
Ghidra 12.0.4 + pyghidra headless. 22,225 of 22,226 functions
successfully decompiled in 75 seconds.

Output: docs/research/decompiled/ (54 files, 688,567 lines of C)

Key findings already identified:
- CLandBlockStruct::ConstructPolygons at chunk_00530000.c:2270
  (split direction formula with 0x0CCAC033 constants)
- Motion command handlers at chunk_00510000.c (0x45000005 etc)
- Motion interpreter at chunk_00520000.c
- Portal space UI at chunk_004D0000.c and chunk_00560000.c

Next: identify CPhysicsObj, CMotionInterp, collision, and movement
functions by cross-referencing against ACE's C# port.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-12 23:25:51 +02:00

14626 lines
380 KiB
C

// Decompiled from acclient.exe — chunk 0x00500000
// Ghidra 12.0.4 + pyghidra headless
// --- FUN_00500460 at 0x00500460 (size: 88) ---
undefined4 * __thiscall FUN_00500460(undefined4 *param_1,byte param_2)
{
undefined4 *puVar1;
LONG LVar2;
*param_1 = &PTR_LAB_007c6da0;
param_1[0xc] = &PTR_LAB_007c6d88;
FUN_004ff770();
puVar1 = (undefined4 *)param_1[0xf];
LVar2 = InterlockedDecrement(puVar1 + 1);
if ((LVar2 == 0) && (puVar1 != (undefined4 *)0x0)) {
(**(code **)*puVar1)(1);
}
param_1[0xc] = &PTR_FUN_0079385c;
FUN_004154b0();
if ((param_2 & 1) != 0) {
operator_delete(param_1);
}
return param_1;
}
// --- FUN_005004c0 at 0x005004C0 (size: 31) ---
void FUN_005004c0(int param_1)
{
if (param_1 != 0) {
FUN_0053ed10(*(undefined4 *)(param_1 + 0x70));
FUN_00536c10(param_1);
}
return;
}
// --- FUN_005004e0 at 0x005004E0 (size: 143) ---
uint FUN_005004e0(undefined4 param_1,undefined4 param_2,uint *param_3,int param_4)
{
uint uVar1;
uint uVar2;
uint uVar3;
if (param_4 == 0) {
uVar2 = FUN_005df4c4();
}
else {
uVar2 = 0xffffffff;
if (*param_3 != 0xffffffff) {
uVar2 = *param_3;
}
uVar1 = param_3[1];
uVar3 = uVar2;
if (uVar1 < uVar2) {
uVar3 = uVar1;
}
uVar2 = (uint)(uVar1 < uVar2);
if (param_3[2] < uVar3) {
uVar2 = 2;
uVar3 = param_3[2];
}
if (param_3[3] < uVar3) {
return 3;
}
}
return uVar2;
}
// --- FUN_00500570 at 0x00500570 (size: 147) ---
undefined4 __thiscall FUN_00500570(int *param_1,uint param_2)
{
int iVar1;
uint uVar2;
if (param_2 < (uint)param_1[2]) {
return 0;
}
if ((uint)param_1[1] < param_2) {
if (param_2 == 0) {
param_1[2] = 0;
param_1[1] = 0;
operator_delete__((void *)*param_1);
*param_1 = 0;
return 1;
}
iVar1 = thunk_FUN_005df0f5(param_2 * 4);
if (iVar1 == 0) {
return 0;
}
if (*param_1 != 0) {
uVar2 = 0;
if (param_1[2] != 0) {
do {
*(undefined4 *)(iVar1 + uVar2 * 4) = *(undefined4 *)(*param_1 + uVar2 * 4);
uVar2 = uVar2 + 1;
} while (uVar2 < (uint)param_1[2]);
}
operator_delete__((void *)*param_1);
}
*param_1 = iVar1;
param_1[1] = param_2;
}
return 1;
}
// --- FUN_00500610 at 0x00500610 (size: 71) ---
undefined4 FUN_00500610(uint *param_1,uint *param_2)
{
uint uVar1;
uVar1 = *param_1 & 0x80000003;
if ((int)uVar1 < 0) {
uVar1 = (uVar1 - 1 | 0xfffffffc) + 1;
}
if (uVar1 != 0) {
uVar1 = 4 - uVar1;
if (*param_2 < uVar1) {
return 0;
}
*param_2 = *param_2 - uVar1;
for (; uVar1 != 0; uVar1 = uVar1 - 1) {
*(undefined1 *)*param_1 = 0;
*param_1 = *param_1 + 1;
}
}
return 1;
}
// --- FUN_00500680 at 0x00500680 (size: 17) ---
void __fastcall FUN_00500680(int param_1)
{
*(undefined4 *)(param_1 + 4) = 0;
*(undefined4 *)(param_1 + 8) = 0;
*(undefined4 *)(param_1 + 0xc) = 0;
*(undefined4 *)(param_1 + 0x10) = 0;
return;
}
// --- FUN_005006a0 at 0x005006A0 (size: 373) ---
void __thiscall
FUN_005006a0(int *param_1,uint *param_2,int *param_3,uint param_4,int param_5,int param_6)
{
undefined4 *puVar1;
int iVar2;
uint *puVar3;
uint uVar4;
int iVar5;
undefined4 local_14 [4];
undefined4 local_4;
uVar4 = *(uint *)(*(int *)(param_1[1] + *param_1 * 4) + 0xc);
*param_2 = uVar4;
puVar1 = (undefined4 *)*param_3;
if (puVar1 == (undefined4 *)0x0) {
param_1[5] = uVar4;
uVar4 = *param_2;
puVar3 = (uint *)thunk_FUN_005df0f5(uVar4 * 0x18 + 4);
if (puVar3 == (uint *)0x0) {
LAB_00500754:
puVar3 = (uint *)0x0;
}
else {
*puVar3 = uVar4;
puVar3 = puVar3 + 1;
FUN_00401000(puVar3,0x18,uVar4,&LAB_00500660);
}
}
else {
if (uVar4 <= (uint)param_1[5]) goto LAB_00500759;
if (puVar1[-1] == 0) {
operator_delete__(puVar1 + -1);
}
else {
(**(code **)*puVar1)(3);
}
uVar4 = *param_2;
puVar3 = (uint *)thunk_FUN_005df0f5(uVar4 * 0x18 + 4);
if (puVar3 == (uint *)0x0) goto LAB_00500754;
*puVar3 = uVar4;
puVar3 = puVar3 + 1;
FUN_00401000(puVar3,0x18,uVar4,&LAB_00500660);
}
*param_3 = (int)puVar3;
LAB_00500759:
local_14[0] = *(undefined4 *)(param_5 + (param_4 & 3) * 4);
local_14[1] = *(undefined4 *)(param_5 + (param_4 + 1 & 3) * 4);
local_14[2] = *(undefined4 *)(param_5 + (param_4 - 2 & 3) * 4);
local_14[3] = *(undefined4 *)(param_5 + (param_4 - 1 & 3) * 4);
uVar4 = 0;
local_4 = *(undefined4 *)(param_5 + 0x10);
if (*param_2 != 0) {
iVar5 = 0;
do {
*(undefined4 *)(*param_3 + 4 + iVar5) =
local_14[*(int *)(*(int *)(*(int *)(*(int *)(*(int *)(param_1[1] + *param_1 * 4) + 0x10)
+ param_6 * 4) + 4) + uVar4 * 4)];
iVar2 = *param_3;
*(undefined4 *)(iVar2 + iVar5 + 8) =
**(undefined4 **)(*(int *)(*(int *)(param_1[1] + *param_1 * 4) + 4) + uVar4 * 4);
*(undefined4 *)(iVar2 + iVar5 + 0xc) =
*(undefined4 *)
(*(int *)(*(int *)(*(int *)(param_1[1] + *param_1 * 4) + 4) + uVar4 * 4) + 4);
uVar4 = uVar4 + 1;
iVar5 = iVar5 + 0x18;
} while (uVar4 < *param_2);
}
return;
}
// --- FUN_00500880 at 0x00500880 (size: 247) ---
undefined4 __thiscall FUN_00500880(int *param_1,uint param_2,uint *param_3)
{
int iVar1;
undefined4 uVar2;
uint *puVar3;
uint uVar4;
int *piVar5;
int iVar6;
char cVar7;
uint *puVar8;
int iVar9;
uint local_8;
iVar1 = *(int *)(*(int *)(param_1[1] + *param_1 * 4) + 0x24);
local_8 = 0;
puVar8 = param_3;
do {
uVar2 = *(undefined4 *)(((int)&DAT_007c6eec - (int)param_3) + (int)puVar8);
iVar9 = 0;
if (0 < iVar1) {
do {
puVar3 = *(uint **)(*(int *)(*(int *)(param_1[1] + *param_1 * 4) + 0x1c) + iVar9 * 4);
uVar4 = *puVar3;
*puVar8 = puVar3[1];
if ((param_2 >> ((byte)uVar2 & 0x1f) & 0x1f) == uVar4) break;
iVar9 = iVar9 + 1;
} while (iVar9 < iVar1);
}
if (iVar9 == iVar1) {
return 0;
}
local_8 = local_8 + 1;
puVar8 = puVar8 + 1;
} while (local_8 < 4);
cVar7 = ((param_2 & 0xc000000) != 0) * '\x02';
if ((param_2 & 0x3000000) != 0) {
cVar7 = cVar7 + '\x01';
}
cVar7 = cVar7 * '\x02';
if ((param_2 & 0xc00000) != 0) {
cVar7 = cVar7 + '\x01';
}
cVar7 = cVar7 * '\x02';
if ((param_2 & 0x300000) != 0) {
cVar7 = cVar7 + '\x01';
}
if (cVar7 != '\0') {
iVar9 = 0;
if (0 < iVar1) {
do {
piVar5 = *(int **)(*(int *)(*(int *)(param_1[1] + *param_1 * 4) + 0x1c) + iVar9 * 4);
iVar6 = *piVar5;
param_3[4] = piVar5[1];
if (iVar6 == 0x20) break;
iVar9 = iVar9 + 1;
} while (iVar9 < iVar1);
}
if (iVar9 == iVar1) {
return 0;
}
}
return 1;
}
// --- FUN_00500980 at 0x00500980 (size: 107) ---
undefined4 __thiscall FUN_00500980(int *param_1,uint param_2,uint *param_3)
{
int iVar1;
uint uVar2;
uint uVar3;
undefined4 *puVar4;
int iVar5;
iVar5 = (uint)((param_2 & 0xc000000) != 0) * 2;
if ((param_2 & 0x3000000) != 0) {
iVar5 = iVar5 + 1;
}
iVar5 = iVar5 * 2;
if ((param_2 & 0xc00000) != 0) {
iVar5 = iVar5 + 1;
}
iVar5 = iVar5 * 2;
if ((param_2 & 0x300000) != 0) {
iVar5 = iVar5 + 1;
}
iVar1 = *(int *)(param_1[1] + *param_1 * 4);
uVar2 = *(uint *)(iVar1 + 0x18);
uVar3 = 0;
if (uVar2 != 0) {
puVar4 = *(undefined4 **)(iVar1 + 0x10);
do {
if (*(int *)*puVar4 == iVar5) {
*param_3 = uVar3;
return 1;
}
uVar3 = uVar3 + 1;
puVar4 = puVar4 + 1;
} while (uVar3 < uVar2);
}
return 0;
}
// --- FUN_005009f0 at 0x005009F0 (size: 72) ---
int __fastcall FUN_005009f0(int param_1)
{
int iVar1;
int iVar2;
int iVar3;
int iVar4;
int iVar5;
int *piVar6;
iVar4 = *(int *)(param_1 + 0xc);
iVar3 = 4;
if (iVar4 != 0) {
piVar6 = *(int **)(param_1 + 4);
do {
iVar1 = *piVar6;
iVar2 = *(int *)(iVar1 + 0xc);
iVar5 = 8;
if (iVar2 != 0) {
iVar5 = iVar2 * 8 + 8;
}
iVar5 = iVar5 + 8 + (iVar2 + 1) * *(int *)(iVar1 + 0x18) * 4;
if (*(int *)(iVar1 + 0x24) != 0) {
iVar5 = iVar5 + *(int *)(iVar1 + 0x24) * 8;
}
iVar3 = iVar3 + iVar5;
piVar6 = piVar6 + 1;
iVar4 = iVar4 + -1;
} while (iVar4 != 0);
}
return iVar3;
}
// --- FUN_00500a40 at 0x00500A40 (size: 227) ---
void __fastcall FUN_00500a40(int param_1)
{
undefined4 *puVar1;
uint uVar2;
uVar2 = 0;
if (*(int *)(param_1 + 0xc) != 0) {
do {
puVar1 = *(undefined4 **)(*(int *)(param_1 + 4) + uVar2 * 4);
if (puVar1 != (undefined4 *)0x0) {
*puVar1 = 0;
puVar1[1] = 0;
operator_delete(puVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0xc));
}
*(undefined4 *)(param_1 + 0xc) = 0;
*(undefined4 *)(param_1 + 8) = 0;
operator_delete__(*(void **)(param_1 + 4));
*(undefined4 *)(param_1 + 4) = 0;
uVar2 = 0;
if (*(int *)(param_1 + 0x18) != 0) {
do {
puVar1 = *(undefined4 **)(*(int *)(param_1 + 0x10) + uVar2 * 4);
if (puVar1 != (undefined4 *)0x0) {
if ((void *)puVar1[1] != (void *)0x0) {
operator_delete__((void *)puVar1[1]);
}
puVar1[1] = 0;
*puVar1 = 0;
operator_delete(puVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x18));
}
*(undefined4 *)(param_1 + 0x18) = 0;
*(undefined4 *)(param_1 + 0x14) = 0;
operator_delete__(*(void **)(param_1 + 0x10));
*(undefined4 *)(param_1 + 0x10) = 0;
uVar2 = 0;
if (*(int *)(param_1 + 0x24) != 0) {
do {
puVar1 = *(undefined4 **)(*(int *)(param_1 + 0x1c) + uVar2 * 4);
if (puVar1 != (undefined4 *)0x0) {
*puVar1 = 0x1f;
puVar1[1] = DAT_00842518;
operator_delete(puVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x24));
}
*(undefined4 *)(param_1 + 0x24) = 0;
*(undefined4 *)(param_1 + 0x20) = 0;
operator_delete__(*(void **)(param_1 + 0x1c));
*(undefined4 *)(param_1 + 0x1c) = 0;
return;
}
// --- FUN_00500b30 at 0x00500B30 (size: 418) ---
uint __thiscall FUN_00500b30(undefined4 *param_1,uint *param_2,uint *param_3)
{
uint uVar1;
undefined4 *puVar2;
uint uVar3;
uint uVar4;
if (3 < *param_3) {
*(undefined4 *)*param_2 = *param_1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar1 = param_1[3];
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar3 = 0;
if (uVar1 != 0) {
do {
puVar2 = *(undefined4 **)(param_1[1] + uVar3 * 4);
if (3 < *param_3) {
*(undefined4 *)*param_2 = *puVar2;
*param_2 = *param_2 + 4;
uVar4 = *param_3;
*param_3 = uVar4 - 4;
if (3 < uVar4 - 4) {
*(undefined4 *)*param_2 = puVar2[1];
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
uVar4 = *param_2 & 0x80000003;
if ((int)uVar4 < 0) {
uVar4 = (uVar4 - 1 | 0xfffffffc) + 1;
}
if (uVar4 != 0) {
uVar4 = 4 - uVar4;
if (uVar4 <= *param_3) {
*param_3 = *param_3 - uVar4;
for (; uVar4 != 0; uVar4 = uVar4 - 1) {
*(undefined1 *)*param_2 = 0;
*param_2 = *param_2 + 1;
}
}
}
uVar3 = uVar3 + 1;
} while (uVar3 < uVar1);
}
uVar1 = param_1[6];
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar3 = 0;
if (uVar1 != 0) {
do {
if (3 < *param_3) {
*(undefined4 *)*param_2 = **(undefined4 **)(param_1[4] + uVar3 * 4);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar4 = 0;
if (param_1[3] != 0) {
do {
if (3 < *param_3) {
*(undefined4 *)*param_2 =
*(undefined4 *)(*(int *)(*(int *)(param_1[4] + uVar3 * 4) + 4) + uVar4 * 4);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar4 = uVar4 + 1;
} while (uVar4 < (uint)param_1[3]);
}
uVar3 = uVar3 + 1;
} while (uVar3 < uVar1);
}
uVar1 = param_1[9];
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar3 = 0;
if (uVar1 != 0) {
do {
puVar2 = *(undefined4 **)(param_1[7] + uVar3 * 4);
if (3 < *param_3) {
*(undefined4 *)*param_2 = *puVar2;
*param_2 = *param_2 + 4;
uVar4 = *param_3;
*param_3 = uVar4 - 4;
if (3 < uVar4 - 4) {
*(undefined4 *)*param_2 = puVar2[1];
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
uVar4 = *param_2 & 0x80000003;
if ((int)uVar4 < 0) {
uVar4 = (uVar4 - 1 | 0xfffffffc) + 1;
}
if (uVar4 != 0) {
uVar4 = 4 - uVar4;
if (uVar4 <= *param_3) {
*param_3 = *param_3 - uVar4;
for (; uVar4 != 0; uVar4 = uVar4 - 1) {
*(undefined1 *)*param_2 = 0;
*param_2 = *param_2 + 1;
}
}
}
uVar3 = uVar3 + 1;
} while (uVar3 < uVar1);
}
return *param_3;
}
// --- FUN_00500ce0 at 0x00500CE0 (size: 175) ---
void __fastcall FUN_00500ce0(int param_1)
{
int *piVar1;
int iVar2;
undefined4 uVar3;
uint uVar4;
undefined4 uVar5;
uint local_20;
local_20 = 0;
if (*(int *)(param_1 + 0xc) != 0) {
do {
piVar1 = *(int **)(*(int *)(param_1 + 4) + local_20 * 4);
if (*piVar1 != DAT_00842518) {
uVar5 = 8;
uVar3 = FUN_004220b0(*piVar1,0);
FUN_0041a4e0(uVar3,uVar5);
}
uVar4 = 0;
if (piVar1[9] != 0) {
do {
iVar2 = *(int *)(*(int *)(piVar1[7] + uVar4 * 4) + 4);
if (iVar2 != DAT_00842518) {
uVar5 = 8;
uVar3 = FUN_004220b0(iVar2,0);
FUN_0041a4e0(uVar3,uVar5);
}
uVar4 = uVar4 + 1;
} while (uVar4 < (uint)piVar1[9]);
}
local_20 = local_20 + 1;
} while (local_20 < *(uint *)(param_1 + 0xc));
}
return;
}
// --- FUN_00500d90 at 0x00500D90 (size: 261) ---
undefined4 __thiscall
FUN_00500d90(uint *param_1,undefined4 param_2,undefined4 param_3,uint *param_4,undefined4 *param_5,
undefined4 param_6,undefined4 param_7,undefined4 param_8,undefined4 param_9)
{
uint uVar1;
int iVar2;
uint uVar3;
uint uVar4;
uint local_8;
uVar1 = FUN_005df4c4();
uVar4 = uVar1;
local_8 = uVar1;
do {
*param_1 = uVar4;
iVar2 = FUN_00500880(*param_5,param_7);
if (iVar2 != 0) {
uVar3 = FUN_005004e0(param_2,param_3,param_5,param_9);
uVar4 = uVar3;
do {
iVar2 = FUN_00500980(param_5[uVar4],param_8);
if (iVar2 != 0) {
*param_4 = uVar4;
return param_5[uVar4];
}
uVar4 = uVar4 + 1 & 3;
} while (uVar4 != uVar3);
uVar4 = (local_8 + 1) % param_1[3];
local_8 = uVar4;
}
} while (uVar4 != uVar1);
*param_1 = 0;
*param_4 = 0;
return *param_5;
}
// --- FUN_00500ea0 at 0x00500EA0 (size: 115) ---
undefined4 __thiscall
FUN_00500ea0(int *param_1,undefined4 param_2,undefined4 param_3,undefined4 param_4,
undefined4 param_5)
{
undefined4 uVar1;
int iVar2;
undefined4 uVar3;
uVar1 = **(undefined4 **)(param_1[1] + *param_1 * 4);
FUN_005006a0(&param_5,param_1 + 4,param_3,param_4,param_5);
iVar2 = FUN_0053efe0();
if (iVar2 != 0) {
FUN_0053ef90(param_5,param_1[4]);
}
uVar3 = FUN_00536fb0(2);
FUN_00537020(uVar1,1);
FUN_00536c60(iVar2);
FUN_00537140(0);
return uVar3;
}
// --- FUN_00500f20 at 0x00500F20 (size: 77) ---
uint __thiscall FUN_00500f20(int param_1,int *param_2,uint *param_3)
{
uint uVar1;
uint uVar2;
uVar1 = *(uint *)(param_1 + 0xc);
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar2 = 0;
if (uVar1 != 0) {
do {
FUN_00500b30(param_2,param_3);
uVar2 = uVar2 + 1;
} while (uVar2 < uVar1);
}
return *param_3;
}
// --- FUN_00500f70 at 0x00500F70 (size: 773) ---
undefined4 __thiscall FUN_00500f70(undefined4 *param_1,uint *param_2,uint *param_3)
{
uint *puVar1;
uint *puVar2;
uint *puVar3;
undefined4 *puVar4;
int iVar5;
undefined4 uVar6;
uint uVar7;
uint *puVar8;
undefined4 *puVar9;
puVar2 = param_3;
puVar1 = param_2;
if (3 < *param_3) {
uVar6 = *(undefined4 *)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
*param_1 = uVar6;
if (3 < *param_3) {
puVar8 = *(uint **)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
param_3 = puVar8;
}
}
if ((param_3 != (uint *)0x0) && (FUN_00500570(param_3), param_3 != (uint *)0x0)) {
param_2 = param_3;
do {
puVar4 = (undefined4 *)FUN_005df0f5(8);
puVar9 = (undefined4 *)0x0;
if (puVar4 != (undefined4 *)0x0) {
*puVar4 = 0;
puVar4[1] = 0;
puVar9 = puVar4;
}
if (3 < *puVar2) {
*puVar9 = *(undefined4 *)*puVar1;
*puVar1 = *puVar1 + 4;
uVar7 = *puVar2;
*puVar2 = uVar7 - 4;
if (3 < uVar7 - 4) {
puVar9[1] = *(undefined4 *)*puVar1;
*puVar1 = *puVar1 + 4;
*puVar2 = *puVar2 - 4;
}
}
uVar7 = *puVar1 & 0x80000003;
if ((int)uVar7 < 0) {
uVar7 = (uVar7 - 1 | 0xfffffffc) + 1;
}
if (uVar7 != 0) {
uVar7 = 4 - uVar7;
if (uVar7 <= *puVar2) {
*puVar2 = *puVar2 - uVar7;
for (; uVar7 != 0; uVar7 = uVar7 - 1) {
*(undefined1 *)*puVar1 = 0;
*puVar1 = *puVar1 + 1;
}
}
}
uVar7 = param_1[2];
if ((uint)param_1[3] < uVar7) {
LAB_0050106e:
*(undefined4 **)(param_1[1] + param_1[3] * 4) = puVar9;
param_1[3] = param_1[3] + 1;
}
else {
if (uVar7 == 0) {
iVar5 = 8;
}
else {
iVar5 = uVar7 * 2;
}
iVar5 = FUN_00500570(iVar5);
if (iVar5 != 0) goto LAB_0050106e;
}
param_2 = (uint *)((int)param_2 + -1);
} while (param_2 != (uint *)0x0);
param_2 = (uint *)0x0;
}
if (3 < *puVar2) {
param_3 = *(uint **)*puVar1;
*puVar1 = (uint)((undefined4 *)*puVar1 + 1);
*puVar2 = *puVar2 - 4;
}
FUN_00500570(param_3);
puVar8 = param_3;
puVar3 = param_3;
if (param_3 != (uint *)0x0) {
do {
param_2 = puVar3;
puVar4 = (undefined4 *)FUN_005df0f5(8);
puVar9 = (undefined4 *)0x0;
if (puVar4 != (undefined4 *)0x0) {
*puVar4 = 0;
puVar4[1] = 0;
puVar9 = puVar4;
}
if (3 < *puVar2) {
*puVar9 = *(undefined4 *)*puVar1;
*puVar1 = *puVar1 + 4;
*puVar2 = *puVar2 - 4;
}
uVar6 = thunk_FUN_005df0f5(param_1[3] * 4);
puVar9[1] = uVar6;
uVar7 = 0;
if (param_1[3] != 0) {
do {
if (3 < *puVar2) {
puVar8 = *(uint **)*puVar1;
*puVar1 = (uint)((undefined4 *)*puVar1 + 1);
*puVar2 = *puVar2 - 4;
}
*(uint **)(puVar9[1] + uVar7 * 4) = puVar8;
uVar7 = uVar7 + 1;
} while (uVar7 < (uint)param_1[3]);
}
uVar7 = param_1[5];
if ((uint)param_1[6] < uVar7) {
LAB_00501155:
*(undefined4 **)(param_1[4] + param_1[6] * 4) = puVar9;
param_1[6] = param_1[6] + 1;
}
else {
if (uVar7 == 0) {
iVar5 = 8;
}
else {
iVar5 = uVar7 * 2;
}
iVar5 = FUN_00500570(iVar5);
if (iVar5 != 0) goto LAB_00501155;
}
puVar3 = (uint *)((int)param_2 + -1);
} while ((uint *)((int)param_2 + -1) != (uint *)0x0);
param_2 = (uint *)0x0;
}
if (3 < *puVar2) {
param_3 = *(uint **)*puVar1;
*puVar1 = (uint)((undefined4 *)*puVar1 + 1);
*puVar2 = *puVar2 - 4;
}
if ((param_3 != (uint *)0x0) && (FUN_00500570(param_3), param_3 != (uint *)0x0)) {
do {
puVar4 = (undefined4 *)FUN_005df0f5(8);
puVar9 = (undefined4 *)0x0;
if (puVar4 != (undefined4 *)0x0) {
*puVar4 = 0x1f;
puVar4[1] = 0;
puVar9 = puVar4;
}
if (3 < *puVar2) {
param_2 = *(uint **)*puVar1;
*puVar1 = (uint)((undefined4 *)*puVar1 + 1);
*puVar2 = *puVar2 - 4;
}
*puVar9 = param_2;
if (3 < *puVar2) {
uVar6 = *(undefined4 *)*puVar1;
*puVar1 = (uint)((undefined4 *)*puVar1 + 1);
*puVar2 = *puVar2 - 4;
puVar9[1] = uVar6;
}
uVar7 = *puVar1 & 0x80000003;
if ((int)uVar7 < 0) {
uVar7 = (uVar7 - 1 | 0xfffffffc) + 1;
}
if (uVar7 != 0) {
uVar7 = 4 - uVar7;
if (uVar7 <= *puVar2) {
*puVar2 = *puVar2 - uVar7;
for (; uVar7 != 0; uVar7 = uVar7 - 1) {
*(undefined1 *)*puVar1 = 0;
*puVar1 = *puVar1 + 1;
}
}
}
uVar7 = param_1[8];
if ((uint)param_1[9] < uVar7) {
LAB_00501253:
*(undefined4 **)(param_1[7] + param_1[9] * 4) = puVar9;
param_1[9] = param_1[9] + 1;
}
else {
if (uVar7 == 0) {
iVar5 = 8;
}
else {
iVar5 = uVar7 * 2;
}
iVar5 = FUN_00500570(iVar5);
if (iVar5 != 0) goto LAB_00501253;
}
param_3 = (uint *)((int)param_3 + -1);
} while (param_3 != (uint *)0x0);
}
return 1;
}
// --- FUN_00501280 at 0x00501280 (size: 146) ---
void __fastcall FUN_00501280(int param_1)
{
void *pvVar1;
undefined4 *puVar2;
uint uVar3;
uVar3 = 0;
if (*(int *)(param_1 + 0xc) != 0) {
do {
pvVar1 = *(void **)(*(int *)(param_1 + 4) + uVar3 * 4);
if (pvVar1 != (void *)0x0) {
FUN_00500a40();
operator_delete__(*(void **)((int)pvVar1 + 0x1c));
operator_delete__(*(void **)((int)pvVar1 + 0x10));
operator_delete__(*(void **)((int)pvVar1 + 4));
operator_delete(pvVar1);
}
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0xc));
}
*(undefined4 *)(param_1 + 0xc) = 0;
*(undefined4 *)(param_1 + 8) = 0;
operator_delete__(*(void **)(param_1 + 4));
*(undefined4 *)(param_1 + 4) = 0;
puVar2 = *(undefined4 **)(param_1 + 0x10);
if (puVar2 != (undefined4 *)0x0) {
if (puVar2[-1] != 0) {
(**(code **)*puVar2)(3);
*(undefined4 *)(param_1 + 0x10) = 0;
return;
}
operator_delete__(puVar2 + -1);
}
*(undefined4 *)(param_1 + 0x10) = 0;
return;
}
// --- FUN_00501320 at 0x00501320 (size: 259) ---
undefined4 __thiscall FUN_00501320(int param_1,undefined4 *param_2,uint *param_3)
{
uint uVar1;
undefined4 *puVar2;
int iVar3;
uint *puVar4;
uint *local_8;
puVar4 = param_3;
if (3 < *param_3) {
puVar4 = *(uint **)*param_2;
*param_2 = (undefined4 *)*param_2 + 1;
*param_3 = *param_3 - 4;
}
FUN_00501280();
if (puVar4 != (uint *)0x0) {
FUN_00500570(puVar4);
}
local_8 = (uint *)0x0;
if (puVar4 == (uint *)0x0) {
return 1;
}
do {
puVar2 = (undefined4 *)FUN_005df0f5(0x28);
if (puVar2 == (undefined4 *)0x0) {
puVar2 = (undefined4 *)0x0;
}
else {
*puVar2 = 0;
puVar2[1] = 0;
puVar2[2] = 0;
puVar2[3] = 0;
puVar2[4] = 0;
puVar2[5] = 0;
puVar2[6] = 0;
puVar2[7] = 0;
puVar2[8] = 0;
puVar2[9] = 0;
}
iVar3 = FUN_00500f70(param_2,param_3);
if (iVar3 == 0) {
return 0;
}
uVar1 = *(uint *)(param_1 + 8);
if (*(uint *)(param_1 + 0xc) < uVar1) {
LAB_005013ec:
*(undefined4 **)(*(int *)(param_1 + 4) + *(int *)(param_1 + 0xc) * 4) = puVar2;
*(int *)(param_1 + 0xc) = *(int *)(param_1 + 0xc) + 1;
}
else {
if (uVar1 == 0) {
iVar3 = 8;
}
else {
iVar3 = uVar1 * 2;
}
iVar3 = FUN_00500570(iVar3);
if (iVar3 != 0) goto LAB_005013ec;
}
local_8 = (uint *)((int)local_8 + 1);
if (puVar4 <= local_8) {
return 1;
}
} while( true );
}
// --- FUN_00501430 at 0x00501430 (size: 22) ---
void __fastcall FUN_00501430(int param_1)
{
FUN_00501280();
operator_delete__(*(void **)(param_1 + 4));
return;
}
// --- FUN_00501450 at 0x00501450 (size: 114) ---
void __fastcall FUN_00501450(int *param_1)
{
undefined4 *puVar1;
LONG LVar2;
puVar1 = (undefined4 *)param_1[3];
LVar2 = InterlockedDecrement(puVar1 + 1);
if ((LVar2 == 0) && (puVar1 != (undefined4 *)0x0)) {
(**(code **)*puVar1)(1);
}
puVar1 = (undefined4 *)param_1[2];
LVar2 = InterlockedDecrement(puVar1 + 1);
if ((LVar2 == 0) && (puVar1 != (undefined4 *)0x0)) {
(**(code **)*puVar1)(1);
}
puVar1 = (undefined4 *)param_1[1];
LVar2 = InterlockedDecrement(puVar1 + 1);
if ((LVar2 == 0) && (puVar1 != (undefined4 *)0x0)) {
(**(code **)*puVar1)(1);
}
puVar1 = (undefined4 *)*param_1;
LVar2 = InterlockedDecrement(puVar1 + 1);
if ((LVar2 == 0) && (puVar1 != (undefined4 *)0x0)) {
(**(code **)*puVar1)(1);
}
return;
}
// --- FUN_005014d0 at 0x005014D0 (size: 84) ---
void __fastcall FUN_005014d0(undefined4 *param_1)
{
operator_delete__((void *)*param_1);
param_1[5] = 0;
param_1[6] = 0;
*param_1 = 0;
param_1[1] = 0;
param_1[2] = 0;
param_1[3] = 0;
param_1[4] = 0;
param_1[7] = 0;
param_1[9] = DAT_0084253c;
param_1[10] = DAT_0084253c;
param_1[8] = 0;
return;
}
// --- FUN_00501530 at 0x00501530 (size: 151) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __thiscall
FUN_00501530(int param_1,float param_2,undefined4 *param_3,undefined4 *param_4,float *param_5)
{
int iVar1;
float *pfVar2;
uint uVar3;
undefined4 *puVar4;
iVar1 = *(int *)(param_1 + 0x10);
if (iVar1 == 0) {
return 0;
}
uVar3 = 0;
if (iVar1 != 1) {
puVar4 = *(undefined4 **)(param_1 + 8);
do {
puVar4 = puVar4 + 1;
if (param_2 < *(float *)*puVar4) break;
uVar3 = uVar3 + 1;
} while (uVar3 < iVar1 - 1U);
}
*param_3 = *(undefined4 *)(*(int *)(param_1 + 8) + uVar3 * 4);
if (uVar3 == *(int *)(param_1 + 0x10) - 1U) {
*param_4 = **(undefined4 **)(param_1 + 8);
*param_5 = (param_2 - *(float *)*param_3) / (_DAT_007938b0 - *(float *)*param_3);
return 1;
}
pfVar2 = (float *)(*(undefined4 **)(param_1 + 8))[uVar3 + 1];
*param_4 = pfVar2;
*param_5 = (param_2 - *(float *)*param_3) / (*pfVar2 - *(float *)*param_3);
return 1;
}
// --- FUN_005015d0 at 0x005015D0 (size: 36) ---
void __fastcall FUN_005015d0(undefined4 *param_1)
{
*param_1 = 0;
param_1[2] = 0;
param_1[3] = 0x40080000;
param_1[4] = 0;
param_1[5] = 0x40340000;
param_1[6] = 0;
param_1[7] = 0;
param_1[8] = 0;
return;
}
// --- FUN_00501600 at 0x00501600 (size: 608) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void FUN_00501600(float param_1,float *param_2,undefined1 *param_3,float *param_4,
undefined1 *param_5)
{
float fVar1;
uint uVar2;
undefined1 uVar3;
undefined1 uVar4;
int iVar5;
float10 fVar6;
float10 fVar7;
float10 fVar8;
float10 fVar9;
int local_14;
uint local_10;
float local_c;
float local_8;
float local_4;
iVar5 = FUN_00501530(param_1,&local_14,&local_10,&param_1);
uVar2 = local_10;
if (iVar5 != 0) {
*param_2 = (*(float *)(local_10 + 0x14) - *(float *)(local_14 + 0x14)) * param_1 +
*(float *)(local_14 + 0x14);
param_2 = (float *)(uint)*(byte *)(local_10 + 0x19);
uVar3 = FUN_005df4c4();
param_2 = (float *)(uint)*(byte *)(local_10 + 0x18);
uVar4 = FUN_005df4c4();
local_10 = (uint)*(byte *)(local_10 + 0x1a);
param_2 = (float *)CONCAT31(param_2._1_3_,uVar4);
uVar4 = FUN_005df4c4();
param_3[2] = uVar4;
param_3[1] = uVar3;
*param_3 = param_2._0_1_;
param_3[3] = 0xff;
fVar9 = ((float10)*(float *)(uVar2 + 4) - (float10)*(float *)(local_14 + 4)) * (float10)param_1
+ (float10)*(float *)(local_14 + 4);
fVar1 = ((*(float *)(uVar2 + 0xc) - *(float *)(local_14 + 0xc)) * param_1 +
*(float *)(local_14 + 0xc)) * (float)_DAT_0079c6b0;
fVar6 = (((float10)*(float *)(uVar2 + 8) - (float10)*(float *)(local_14 + 8)) * (float10)param_1
+ (float10)*(float *)(local_14 + 8)) * (float10)_DAT_0079c6b0;
fVar7 = (float10)fcos((float10)fVar1);
fVar8 = (float10)fsin(fVar6);
local_c = (float)(fVar9 * fVar8 * fVar7);
fVar6 = (float10)fcos(fVar6);
*param_4 = local_c;
local_8 = (float)(fVar9 * fVar6 * fVar7);
fVar6 = (float10)fsin((float10)fVar1);
param_4[1] = local_8;
local_4 = (float)(fVar6 * fVar9);
param_4[2] = local_4;
param_2 = (float *)(uint)*(byte *)(uVar2 + 0x11);
uVar3 = FUN_005df4c4();
param_2 = (float *)(uint)*(byte *)(uVar2 + 0x10);
uVar4 = FUN_005df4c4();
param_3 = (undefined1 *)(uint)*(byte *)(uVar2 + 0x12);
param_2 = (float *)CONCAT31(param_2._1_3_,uVar4);
uVar4 = FUN_005df4c4();
param_5[2] = uVar4;
param_5[1] = uVar3;
*param_5 = param_2._0_1_;
param_5[3] = 0xff;
return;
}
*param_2 = 0.3;
param_3[2] = 0xff;
param_3[1] = 0xff;
*param_3 = 0xff;
param_3[3] = 0xff;
param_5[2] = 0xff;
param_5[1] = 0xff;
*param_5 = 0xff;
param_5[3] = 0xff;
*param_4 = 0.5;
param_4[1] = 0.0;
param_4[2] = 0.8;
return;
}
// --- FUN_00501860 at 0x00501860 (size: 304) ---
undefined4 FUN_00501860(uint param_1,float *param_2,float *param_3,undefined1 *param_4)
{
undefined1 uVar1;
undefined1 uVar2;
int iVar3;
float local_8;
int local_4;
iVar3 = FUN_00501530(param_1,&param_1,&local_4,&local_8);
if ((((iVar3 != 0) && (param_1 != 0)) && (*(int *)(param_1 + 0x1c) != 0)) &&
((local_4 != 0 && (*(int *)(local_4 + 0x1c) != 0)))) {
*param_2 = (*(float *)(local_4 + 0x20) - *(float *)(param_1 + 0x20)) * local_8 +
*(float *)(param_1 + 0x20);
*param_3 = (*(float *)(local_4 + 0x24) - *(float *)(param_1 + 0x24)) * local_8 +
*(float *)(param_1 + 0x24);
param_1 = (uint)*(byte *)(local_4 + 0x29);
uVar1 = FUN_005df4c4();
param_1 = (uint)*(byte *)(local_4 + 0x28);
uVar2 = FUN_005df4c4();
param_1 = CONCAT31(param_1._1_3_,uVar2);
param_2 = (float *)(uint)*(byte *)(local_4 + 0x2a);
uVar2 = FUN_005df4c4();
param_4[1] = uVar1;
param_4[2] = uVar2;
*param_4 = (undefined1)param_1;
param_4[3] = 0xff;
return 1;
}
return 0;
}
// --- FUN_00501990 at 0x00501990 (size: 131) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __fastcall FUN_00501990(uint *param_1)
{
float fVar1;
float fVar2;
int iVar3;
int iVar4;
uint uVar5;
int iVar6;
if (DAT_008ee9c8 == 0) {
iVar4 = 0;
iVar6 = 0;
iVar3 = 0;
}
else {
iVar4 = *(int *)(DAT_008ee9c8 + 0x68);
iVar6 = *(int *)(DAT_008ee9c8 + 0x10);
iVar3 = *(int *)(DAT_008ee9c8 + 100);
}
iVar4 = (iVar3 * iVar6 + iVar4) * 0x6a42fdb2 + -0x7541e9ae;
fVar1 = (float)iVar4;
if (iVar4 < 0) {
fVar1 = fVar1 + _DAT_0079920c;
}
fVar2 = (float)(int)param_1[8];
if ((int)param_1[8] < 0) {
fVar2 = fVar2 + _DAT_0079920c;
}
floor((double)(fVar2 * fVar1 * _DAT_007c6f10));
uVar5 = FUN_005df4c4();
*param_1 = uVar5;
if (param_1[8] <= uVar5) {
*param_1 = 0;
}
return;
}
// --- FUN_00501a20 at 0x00501A20 (size: 253) ---
uint __thiscall FUN_00501a20(int param_1,int *param_2,uint *param_3)
{
uint uVar1;
if (3 < *param_3) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 4);
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 8);
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0xc);
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0x10);
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0x14);
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0x18);
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0x24);
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0x28);
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0x20);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
}
}
}
}
}
}
}
FUN_00500610(param_2,param_3);
return *param_3;
}
// --- FUN_00501b20 at 0x00501B20 (size: 244) ---
undefined4 __thiscall FUN_00501b20(int param_1,int *param_2,uint *param_3)
{
uint uVar1;
undefined4 uVar2;
FUN_005014d0();
if (3 < *param_3) {
*(undefined4 *)(param_1 + 4) = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)(param_1 + 8) = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)(param_1 + 0xc) = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)(param_1 + 0x10) = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)(param_1 + 0x14) = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)(param_1 + 0x18) = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
}
}
}
}
*(undefined4 *)(param_1 + 0x1c) = 0;
if (3 < *param_3) {
uVar2 = *(undefined4 *)*param_2;
*param_2 = (int)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
*(undefined4 *)(param_1 + 0x24) = uVar2;
if (3 < *param_3) {
uVar2 = *(undefined4 *)*param_2;
*param_2 = (int)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
*(undefined4 *)(param_1 + 0x28) = uVar2;
if (3 < *param_3) {
*(undefined4 *)(param_1 + 0x20) = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
}
FUN_00500610(param_2,param_3);
return 1;
}
// --- FUN_00501c20 at 0x00501C20 (size: 168) ---
uint __thiscall FUN_00501c20(undefined4 *param_1,int *param_2,uint *param_3)
{
uint uVar1;
if (3 < *param_3) {
*(undefined4 *)*param_2 = *param_1;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[2];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[3];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[4];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[5];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[6];
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
}
}
}
}
FUN_00500610(param_2,param_3);
return *param_3;
}
// --- FUN_00501cd0 at 0x00501CD0 (size: 167) ---
undefined4 __thiscall FUN_00501cd0(undefined4 *param_1,int *param_2,uint *param_3)
{
uint uVar1;
undefined4 uVar2;
if (3 < *param_3) {
*param_1 = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
uVar2 = *(undefined4 *)*param_2;
*param_2 = (int)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
param_1[2] = uVar2;
if (3 < *param_3) {
param_1[3] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[4] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[5] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[6] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
}
}
}
}
FUN_00500610(param_2,param_3);
return 1;
}
// --- FUN_00501d80 at 0x00501D80 (size: 88) ---
void __fastcall FUN_00501d80(int param_1)
{
void *pvVar1;
uint uVar2;
uVar2 = 0;
if (*(int *)(param_1 + 0x34) != 0) {
do {
pvVar1 = *(void **)(*(int *)(param_1 + 0x2c) + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x34));
}
*(undefined4 *)(param_1 + 0x34) = 0;
*(undefined4 *)(param_1 + 0x30) = 0;
operator_delete__(*(void **)(param_1 + 0x2c));
*(undefined4 *)(param_1 + 0x2c) = 0;
operator_delete__(*(void **)(param_1 + 0x2c));
return;
}
// --- FUN_00501de0 at 0x00501DE0 (size: 367) ---
uint __thiscall FUN_00501de0(undefined4 *param_1,int *param_2,uint *param_3)
{
uint uVar1;
uint uVar2;
if (3 < *param_3) {
*(undefined4 *)*param_2 = *param_1;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[1];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[2];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[3];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[4];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[5];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[6];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[8];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[9];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[10];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[7];
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
}
}
}
}
}
}
}
}
}
FUN_00500610(param_2,param_3);
uVar1 = param_1[0xd];
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar2 = 0;
if (uVar1 != 0) {
do {
FUN_00501c20(param_2,param_3);
uVar2 = uVar2 + 1;
} while (uVar2 < uVar1);
}
return *param_3;
}
// --- FUN_00501f50 at 0x00501F50 (size: 225) ---
void __fastcall FUN_00501f50(int param_1)
{
int iVar1;
int iVar2;
int iVar3;
undefined4 uVar4;
uint uVar5;
undefined4 uVar6;
undefined4 local_24;
undefined4 local_20;
local_20 = 0;
if (*(int *)(param_1 + 0x20) != 0) {
do {
iVar1 = *(int *)(*(int *)(param_1 + 0x18) + local_20 * 4);
uVar5 = 0;
if (*(int *)(iVar1 + 0x1c) != 0) {
do {
iVar2 = *(int *)(*(int *)(*(int *)(iVar1 + 0x14) + uVar5 * 4) + 0x24);
if (iVar2 != DAT_0084253c) {
uVar6 = 8;
uVar4 = FUN_004220b0(iVar2,0);
FUN_0041a4e0(uVar4,uVar6);
}
uVar5 = uVar5 + 1;
} while (uVar5 < *(uint *)(iVar1 + 0x1c));
}
local_24 = 0;
if (*(int *)(iVar1 + 0x10) != 0) {
do {
iVar2 = *(int *)(*(int *)(iVar1 + 8) + local_24 * 4);
uVar5 = 0;
if (*(int *)(iVar2 + 0x34) != 0) {
do {
iVar3 = *(int *)(*(int *)(*(int *)(iVar2 + 0x2c) + uVar5 * 4) + 8);
if (iVar3 != DAT_0084253c) {
uVar6 = 8;
uVar4 = FUN_004220b0(iVar3,0);
FUN_0041a4e0(uVar4,uVar6);
}
uVar5 = uVar5 + 1;
} while (uVar5 < *(uint *)(iVar2 + 0x34));
}
local_24 = local_24 + 1;
} while (local_24 < *(uint *)(iVar1 + 0x10));
}
local_20 = local_20 + 1;
} while (local_20 < *(uint *)(param_1 + 0x20));
}
return;
}
// --- FUN_00502040 at 0x00502040 (size: 184) ---
undefined4 __thiscall FUN_00502040(int *param_1,uint param_2)
{
uint *puVar1;
uint *puVar2;
int iVar3;
int iVar4;
uint uVar5;
undefined4 *puVar6;
undefined4 *puVar7;
if ((uint)param_1[2] <= param_2) {
if (param_2 <= (uint)param_1[1]) {
return 1;
}
if (param_2 == 0) {
FUN_005225d0();
return 1;
}
puVar2 = (uint *)thunk_FUN_005df0f5(param_2 * 0x2c + 4);
if (puVar2 != (uint *)0x0) {
puVar1 = puVar2 + 1;
*puVar2 = param_2;
FUN_00401000(puVar1,0x2c,param_2,FUN_0050a140);
if (puVar1 != (uint *)0x0) {
if (*param_1 != 0) {
uVar5 = 0;
if (param_1[2] != 0) {
iVar3 = 0;
do {
puVar6 = (undefined4 *)(*param_1 + iVar3);
puVar7 = (undefined4 *)(iVar3 + (int)puVar1);
for (iVar4 = 0xb; iVar4 != 0; iVar4 = iVar4 + -1) {
*puVar7 = *puVar6;
puVar6 = puVar6 + 1;
puVar7 = puVar7 + 1;
}
uVar5 = uVar5 + 1;
iVar3 = iVar3 + 0x2c;
} while (uVar5 < (uint)param_1[2]);
}
if (*param_1 != 0) {
operator_delete__((void *)(*param_1 + -4));
}
}
*param_1 = (int)puVar1;
param_1[1] = param_2;
return 1;
}
}
}
return 0;
}
// --- FUN_00502100 at 0x00502100 (size: 462) ---
uint __thiscall FUN_00502100(undefined4 *param_1,int *param_2,uint *param_3)
{
uint uVar1;
undefined4 *puVar2;
int iVar3;
uint *puVar4;
undefined4 *puVar5;
if (3 < *param_3) {
*param_1 = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[1] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[2] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[3] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[4] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[5] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[6] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[8] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[9] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[10] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
param_1[7] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
}
}
}
}
}
}
}
}
}
FUN_00500610(param_2,param_3);
puVar4 = param_3;
if (3 < *param_3) {
puVar4 = *(uint **)*param_2;
*param_2 = (int)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
}
FUN_00500570(puVar4);
do {
if (puVar4 == (uint *)0x0) {
return *param_3;
}
puVar2 = (undefined4 *)FUN_005df0f5(0x1c);
puVar5 = (undefined4 *)0x0;
if (puVar2 != (undefined4 *)0x0) {
*puVar2 = 0;
puVar2[1] = 0;
puVar2[2] = 0;
puVar2[3] = 0;
puVar2[5] = 0;
puVar2[6] = 0;
puVar2[4] = 0xbf800000;
puVar5 = puVar2;
}
FUN_00501cd0(param_2,param_3);
uVar1 = param_1[0xc];
if ((uint)param_1[0xd] < uVar1) {
LAB_005022b4:
*(undefined4 **)(param_1[0xb] + param_1[0xd] * 4) = puVar5;
param_1[0xd] = param_1[0xd] + 1;
}
else {
if (uVar1 == 0) {
iVar3 = 8;
}
else {
iVar3 = uVar1 * 2;
}
iVar3 = FUN_00500570(iVar3);
if (iVar3 != 0) goto LAB_005022b4;
}
puVar4 = (uint *)((int)puVar4 + -1);
} while( true );
}
// --- FUN_005022d0 at 0x005022D0 (size: 232) ---
void __fastcall FUN_005022d0(int param_1)
{
void *pvVar1;
undefined4 *puVar2;
uint uVar3;
uVar3 = 0;
*(undefined4 *)(param_1 + 4) = 0;
if (*(int *)(param_1 + 0x10) != 0) {
do {
pvVar1 = *(void **)(*(int *)(param_1 + 8) + uVar3 * 4);
if (pvVar1 != (void *)0x0) {
FUN_00501d80();
operator_delete(pvVar1);
}
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0x10));
}
*(undefined4 *)(param_1 + 0x10) = 0;
*(undefined4 *)(param_1 + 0xc) = 0;
operator_delete__(*(void **)(param_1 + 8));
*(undefined4 *)(param_1 + 8) = 0;
uVar3 = 0;
if (*(int *)(param_1 + 0x1c) != 0) {
do {
puVar2 = *(undefined4 **)(*(int *)(param_1 + 0x14) + uVar3 * 4);
if (puVar2 != (undefined4 *)0x0) {
operator_delete__((void *)*puVar2);
puVar2[5] = 0;
puVar2[6] = 0;
*puVar2 = 0;
puVar2[1] = 0;
puVar2[2] = 0;
puVar2[3] = 0;
puVar2[4] = 0;
puVar2[7] = 0;
puVar2[9] = DAT_0084253c;
puVar2[10] = DAT_0084253c;
puVar2[8] = 0;
operator_delete(puVar2);
}
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0x1c));
}
*(undefined4 *)(param_1 + 0x1c) = 0;
*(undefined4 *)(param_1 + 0x18) = 0;
operator_delete__(*(void **)(param_1 + 0x14));
*(undefined4 *)(param_1 + 0x14) = 0;
return;
}
// --- FUN_005023c0 at 0x005023C0 (size: 132) ---
int __fastcall FUN_005023c0(int *param_1)
{
uint uVar1;
uint uVar2;
int iVar3;
int iVar4;
int iVar5;
int *piVar6;
uVar1 = *(int *)(*param_1 + 8) - 1;
iVar3 = 0;
if (0xfffe < uVar1) {
iVar3 = 4;
}
uVar1 = iVar3 + 2 + uVar1;
uVar2 = uVar1 & 3;
if (uVar2 == 0) {
iVar3 = 0;
}
else {
iVar3 = 4 - uVar2;
}
uVar1 = iVar3 + 4 + uVar1;
uVar2 = uVar1 & 3;
if (uVar2 == 0) {
iVar3 = 0;
}
else {
iVar3 = 4 - uVar2;
}
iVar3 = uVar1 + 4 + iVar3;
iVar5 = param_1[4];
if (iVar5 != 0) {
piVar6 = (int *)param_1[2];
do {
iVar4 = 0x30;
if (*(int *)(*piVar6 + 0x34) != 0) {
iVar4 = (*(int *)(*piVar6 + 0x34) * 3 + 6) * 8;
}
iVar3 = iVar3 + iVar4;
piVar6 = piVar6 + 1;
iVar5 = iVar5 + -1;
} while (iVar5 != 0);
}
iVar3 = iVar3 + 4;
if (param_1[7] != 0) {
iVar3 = iVar3 + param_1[7] * 0x24;
}
return iVar3;
}
// --- FUN_00502450 at 0x00502450 (size: 166) ---
uint __thiscall FUN_00502450(int param_1,int *param_2,uint *param_3)
{
int iVar1;
uint uVar2;
if (3 < *param_3) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 4);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
iVar1 = FUN_004fd290(param_2,*param_3);
*param_3 = *param_3 - iVar1;
FUN_00500610(param_2,param_3);
if (3 < *param_3) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0x1c);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar2 = 0;
if (*(int *)(param_1 + 0x1c) != 0) {
do {
FUN_00501a20(param_2,param_3);
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x1c));
}
if (3 < *param_3) {
*(undefined4 *)*param_2 = *(undefined4 *)(param_1 + 0x10);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar2 = 0;
if (*(int *)(param_1 + 0x10) != 0) {
do {
FUN_00501de0(param_2,param_3);
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x10));
}
return *param_3;
}
// --- FUN_00502500 at 0x00502500 (size: 61) ---
uint __fastcall FUN_00502500(int param_1)
{
int iVar1;
int iVar2;
uint uVar3;
uVar3 = 0x14;
for (iVar2 = *(int *)(param_1 + 0x20); iVar2 != 0; iVar2 = iVar2 + -1) {
iVar1 = FUN_005023c0();
uVar3 = uVar3 + iVar1;
}
if ((uVar3 & 3) != 0) {
return (4 - (uVar3 & 3)) + uVar3;
}
return uVar3;
}
// --- FUN_00502540 at 0x00502540 (size: 127) ---
uint __thiscall FUN_00502540(int param_1,int *param_2,uint *param_3)
{
uint uVar1;
uint uVar2;
if (7 < *param_3) {
*(undefined8 *)*param_2 = *(undefined8 *)(param_1 + 8);
*param_2 = *param_2 + 8;
uVar1 = *param_3;
*param_3 = uVar1 - 8;
if (7 < uVar1 - 8) {
*(undefined8 *)*param_2 = *(undefined8 *)(param_1 + 0x10);
*param_2 = *param_2 + 8;
*param_3 = *param_3 - 8;
}
}
FUN_00500610(param_2,param_3);
uVar1 = *(uint *)(param_1 + 0x20);
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar2 = 0;
if (uVar1 != 0) {
do {
FUN_00502450(param_2,param_3);
uVar2 = uVar2 + 1;
} while (uVar2 < uVar1);
}
return *param_3;
}
// --- FUN_005025c0 at 0x005025C0 (size: 605) ---
undefined4 __thiscall FUN_005025c0(int *param_1,int *param_2,uint *param_3)
{
int *piVar1;
int iVar2;
uint uVar3;
undefined4 *puVar4;
uint uVar5;
int local_14;
undefined4 *local_10;
int local_c;
if (3 < *param_3) {
param_1[1] = *(int *)*param_2;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
iVar2 = FUN_004fd460(param_2,*param_3);
if (iVar2 == 0) {
return 0;
}
uVar3 = *(int *)(*param_1 + 8) - 1;
iVar2 = 0;
if (0xfffe < uVar3) {
iVar2 = 4;
}
uVar3 = iVar2 + 2 + uVar3;
uVar5 = uVar3 & 3;
if (uVar5 == 0) {
iVar2 = 0;
}
else {
iVar2 = 4 - uVar5;
}
*param_3 = *param_3 - (iVar2 + uVar3);
FUN_00500610(param_2,param_3);
if (3 < *param_3) {
local_14 = *(int *)*param_2;
*param_2 = (int)((int *)*param_2 + 1);
*param_3 = *param_3 - 4;
}
FUN_00500570(local_14);
if (local_14 != 0) {
local_c = local_14;
do {
local_10 = (undefined4 *)FUN_005df0f5(0x2c);
if (local_10 == (undefined4 *)0x0) {
local_10 = (undefined4 *)0x0;
}
else {
*local_10 = 0;
local_10[1] = 0;
local_10[2] = 0;
local_10[3] = 0;
local_10[4] = 0;
local_10[5] = 0;
local_10[6] = 0;
local_10[7] = 0;
local_10[8] = 0;
local_10[9] = 0;
local_10[10] = 0;
}
FUN_00501b20(param_2,param_3);
uVar3 = param_1[6];
if ((uint)param_1[7] < uVar3) {
LAB_005026e4:
*(undefined4 **)(param_1[5] + param_1[7] * 4) = local_10;
param_1[7] = param_1[7] + 1;
}
else {
if (uVar3 == 0) {
iVar2 = 8;
}
else {
iVar2 = uVar3 * 2;
}
iVar2 = FUN_00500570(iVar2);
if (iVar2 != 0) goto LAB_005026e4;
}
local_c = local_c + -1;
} while (local_c != 0);
}
if (3 < *param_3) {
local_14 = *(int *)*param_2;
*param_2 = (int)((int *)*param_2 + 1);
*param_3 = *param_3 - 4;
}
FUN_00500570(local_14);
if (local_14 != 0) {
local_10 = (undefined4 *)local_14;
do {
puVar4 = (undefined4 *)FUN_005df0f5(0x38);
if (puVar4 == (undefined4 *)0x0) {
puVar4 = (undefined4 *)0x0;
}
else {
*puVar4 = 0;
puVar4[1] = 0;
puVar4[2] = 0;
puVar4[3] = 0;
puVar4[5] = 0;
puVar4[7] = 0;
puVar4[8] = 0;
puVar4[9] = 0;
puVar4[0xb] = 0;
puVar4[0xc] = 0;
puVar4[0xd] = 0;
*(undefined1 *)((int)puVar4 + 0x12) = 0xff;
*(undefined1 *)((int)puVar4 + 0x11) = 0xff;
*(undefined1 *)(puVar4 + 4) = 0xff;
*(undefined1 *)((int)puVar4 + 0x13) = 0xff;
*(undefined1 *)((int)puVar4 + 0x1a) = 0xff;
*(undefined1 *)((int)puVar4 + 0x19) = 0xff;
*(undefined1 *)(puVar4 + 6) = 0xff;
*(undefined1 *)((int)puVar4 + 0x1b) = 0xff;
*(undefined1 *)((int)puVar4 + 0x2a) = 0xff;
*(undefined1 *)((int)puVar4 + 0x29) = 0xff;
*(undefined1 *)(puVar4 + 10) = 0xff;
*(undefined1 *)((int)puVar4 + 0x2b) = 0xff;
}
FUN_00502100(param_2,param_3);
uVar3 = 0;
if (puVar4[0xd] != 0) {
do {
piVar1 = *(int **)(puVar4[0xb] + uVar3 * 4);
piVar1[1] = *(int *)(param_1[5] + *piVar1 * 4);
uVar3 = uVar3 + 1;
} while (uVar3 < (uint)puVar4[0xd]);
}
uVar3 = param_1[3];
if ((uint)param_1[4] < uVar3) {
LAB_005027f9:
*(undefined4 **)(param_1[2] + param_1[4] * 4) = puVar4;
param_1[4] = param_1[4] + 1;
}
else {
if (uVar3 == 0) {
iVar2 = 8;
}
else {
iVar2 = uVar3 * 2;
}
iVar2 = FUN_00500570(iVar2);
if (iVar2 != 0) goto LAB_005027f9;
}
local_10 = (undefined4 *)((int)local_10 + -1);
} while (local_10 != (undefined4 *)0x0);
}
return 1;
}
// --- FUN_00502820 at 0x00502820 (size: 325) ---
undefined4 __thiscall FUN_00502820(int param_1,int *param_2,uint *param_3)
{
undefined4 *puVar1;
uint uVar2;
int *piVar3;
int *piVar4;
uint *puVar5;
int iVar6;
LONG *lpAddend;
int *local_8;
puVar5 = param_3;
piVar4 = param_2;
if (7 < *param_3) {
puVar1 = (undefined4 *)*param_2;
*(undefined4 *)(param_1 + 8) = *puVar1;
*(undefined4 *)(param_1 + 0xc) = puVar1[1];
*param_2 = *param_2 + 8;
uVar2 = *param_3;
*param_3 = uVar2 - 8;
if (7 < uVar2 - 8) {
puVar1 = (undefined4 *)*param_2;
*(undefined4 *)(param_1 + 0x10) = *puVar1;
*(undefined4 *)(param_1 + 0x14) = puVar1[1];
*param_2 = *param_2 + 8;
*param_3 = *param_3 - 8;
}
}
FUN_00500610(param_2,param_3);
if (3 < *param_3) {
piVar3 = *(int **)*param_2;
*param_2 = (int)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
param_2 = piVar3;
}
FUN_00500570(param_2);
local_8 = (int *)0x0;
if (param_2 != (int *)0x0) {
do {
param_3 = (uint *)FUN_005df0f5(0x20);
if (param_3 == (uint *)0x0) {
param_3 = (uint *)0x0;
}
else {
lpAddend = (LONG *)(DAT_008ef11c + 4);
*param_3 = DAT_008ef11c;
InterlockedIncrement(lpAddend);
param_3[1] = 0;
param_3[2] = 0;
param_3[3] = 0;
param_3[4] = 0;
param_3[5] = 0;
param_3[6] = 0;
param_3[7] = 0;
}
iVar6 = FUN_005025c0(piVar4,puVar5);
if (iVar6 == 0) {
return 0;
}
uVar2 = *(uint *)(param_1 + 0x1c);
if (*(uint *)(param_1 + 0x20) < uVar2) {
LAB_00502926:
*(uint **)(*(int *)(param_1 + 0x18) + *(int *)(param_1 + 0x20) * 4) = param_3;
*(int *)(param_1 + 0x20) = *(int *)(param_1 + 0x20) + 1;
}
else {
if (uVar2 == 0) {
iVar6 = 8;
}
else {
iVar6 = uVar2 * 2;
}
iVar6 = FUN_00500570(iVar6);
if (iVar6 != 0) goto LAB_00502926;
}
local_8 = (int *)((int)local_8 + 1);
} while (local_8 < param_2);
}
return 1;
}
// --- FUN_00502970 at 0x00502970 (size: 150) ---
void __fastcall FUN_00502970(undefined4 *param_1)
{
int *piVar1;
undefined4 *puVar2;
LONG LVar3;
uint uVar4;
uVar4 = 0;
*param_1 = 0;
param_1[2] = 0;
param_1[3] = 0x40080000;
param_1[4] = 0;
param_1[5] = 0x40340000;
if (param_1[8] != 0) {
do {
piVar1 = *(int **)(param_1[6] + uVar4 * 4);
if (piVar1 != (int *)0x0) {
FUN_005022d0();
operator_delete__((void *)piVar1[5]);
operator_delete__((void *)piVar1[2]);
puVar2 = (undefined4 *)*piVar1;
LVar3 = InterlockedDecrement(puVar2 + 1);
if ((LVar3 == 0) && (puVar2 != (undefined4 *)0x0)) {
(**(code **)*puVar2)(1);
}
operator_delete(piVar1);
}
uVar4 = uVar4 + 1;
} while (uVar4 < (uint)param_1[8]);
}
param_1[8] = 0;
param_1[7] = 0;
operator_delete__((void *)param_1[6]);
param_1[6] = 0;
return;
}
// --- FUN_00502a10 at 0x00502A10 (size: 896) ---
undefined4 __thiscall FUN_00502a10(int *param_1,int *param_2,int *param_3)
{
float fVar1;
int iVar2;
uint uVar3;
int iVar4;
int *piVar5;
uint uVar6;
uint uVar7;
int iVar8;
int *piVar9;
undefined4 *puVar10;
undefined4 uVar11;
undefined4 *puVar12;
uint local_38;
int local_34;
int local_30;
undefined4 local_2c [11];
piVar5 = param_3;
uVar6 = param_3[2];
iVar2 = *(int *)(param_1[6] + *param_1 * 4);
uVar3 = *(uint *)(iVar2 + 0x1c);
if (uVar6 < uVar3) {
puVar10 = local_2c;
for (iVar8 = 0xb; iVar8 != 0; iVar8 = iVar8 + -1) {
*puVar10 = 0;
puVar10 = puVar10 + 1;
}
param_3 = (int *)(uVar3 - uVar6);
do {
uVar6 = piVar5[1];
if ((uint)piVar5[2] < uVar6) {
LAB_00502a67:
puVar10 = local_2c;
puVar12 = (undefined4 *)(piVar5[2] * 0x2c + *piVar5);
for (iVar8 = 0xb; iVar8 != 0; iVar8 = iVar8 + -1) {
*puVar12 = *puVar10;
puVar10 = puVar10 + 1;
puVar12 = puVar12 + 1;
}
piVar5[2] = piVar5[2] + 1;
}
else {
if (uVar6 == 0) {
iVar8 = 8;
}
else {
iVar8 = uVar6 * 2;
}
iVar8 = FUN_00502040(iVar8);
if (iVar8 != 0) goto LAB_00502a67;
}
param_3 = (int *)((int)param_3 + -1);
} while (param_3 != (int *)0x0);
}
uVar6 = piVar5[2];
while (uVar3 < uVar6) {
if (uVar3 < (uint)piVar5[2]) {
uVar6 = piVar5[2] - 1;
piVar5[2] = uVar6;
if (uVar3 != uVar6) {
puVar10 = (undefined4 *)(uVar6 * 0x2c + *piVar5);
puVar12 = (undefined4 *)(uVar3 * 0x2c + *piVar5);
for (iVar8 = 0xb; iVar8 != 0; iVar8 = iVar8 + -1) {
*puVar12 = *puVar10;
puVar10 = puVar10 + 1;
puVar12 = puVar12 + 1;
}
}
}
uVar6 = piVar5[2];
}
uVar6 = 0;
if (*(int *)(iVar2 + 0x1c) != 0) {
iVar8 = 0;
do {
iVar4 = *(int *)(*(int *)(iVar2 + 0x14) + uVar6 * 4);
if ((*(float *)(iVar4 + 4) == *(float *)(iVar4 + 8)) ||
((uVar11 = DAT_0084253c, *(float *)(iVar4 + 4) < (float)param_2 &&
((float)param_2 < *(float *)(iVar4 + 8))))) {
uVar11 = *(undefined4 *)(iVar4 + 0x24);
}
*(undefined4 *)(iVar8 + *piVar5) = uVar11;
*(undefined4 *)(iVar8 + 4 + *piVar5) = *(undefined4 *)(iVar4 + 0x28);
*(undefined4 *)(iVar8 + 0x28 + *piVar5) = *(undefined4 *)(iVar4 + 0x20);
*(undefined4 *)(iVar8 + 8 + *piVar5) = 0;
if (*(float *)(iVar4 + 4) == *(float *)(iVar4 + 8)) {
fVar1 = *(float *)(iVar4 + 0xc);
}
else {
fVar1 = (((float)param_2 - *(float *)(iVar4 + 4)) *
(*(float *)(iVar4 + 0x10) - *(float *)(iVar4 + 0xc))) /
(*(float *)(iVar4 + 8) - *(float *)(iVar4 + 4)) + *(float *)(iVar4 + 0xc);
}
*(float *)(iVar8 + 0xc + *piVar5) = fVar1;
puVar10 = (undefined4 *)(iVar8 + 0x10 + *piVar5);
*puVar10 = *(undefined4 *)(iVar4 + 0x14);
puVar10[1] = *(undefined4 *)(iVar4 + 0x18);
puVar10[2] = *(undefined4 *)(iVar4 + 0x1c);
*(undefined4 *)(iVar8 + 0x20 + *piVar5) = 0xbf800000;
*(undefined4 *)(iVar8 + 0x24 + *piVar5) = 0xbf800000;
*(undefined4 *)(iVar8 + 0x1c + *piVar5) = 0xbf800000;
uVar6 = uVar6 + 1;
iVar8 = iVar8 + 0x2c;
} while (uVar6 < *(uint *)(iVar2 + 0x1c));
}
iVar8 = FUN_00501530(param_2,&local_34,&local_30,&param_3);
if ((iVar8 != 0) && (local_38 = 0, *(int *)(local_34 + 0x34) != 0)) {
do {
iVar8 = *(int *)(*(int *)(local_34 + 0x2c) + local_38 * 4);
iVar4 = *(int *)(iVar8 + 4);
uVar6 = 0;
if (*(uint *)(iVar2 + 0x1c) != 0) {
piVar9 = *(int **)(iVar2 + 0x14);
do {
if (iVar4 == *piVar9) break;
uVar6 = uVar6 + 1;
piVar9 = piVar9 + 1;
} while (uVar6 < *(uint *)(iVar2 + 0x1c));
}
if (*(int *)(iVar8 + 8) != 0) {
*(int *)(uVar6 * 0x2c + *piVar5) = *(int *)(iVar8 + 8);
}
fVar1 = *(float *)(*(int *)(*(int *)(local_34 + 0x2c) + local_38 * 4) + 0xc);
if (fVar1 != DAT_00796344) {
*(float *)(uVar6 * 0x2c + 8 + *piVar5) = fVar1;
}
if (((DAT_00796344 < *(float *)(iVar8 + 0x14)) || (DAT_00796344 < *(float *)(iVar8 + 0x18)))
|| (DAT_00796344 <= *(float *)(iVar8 + 0x10))) {
uVar3 = *(uint *)(local_30 + 0x34);
uVar7 = 0;
if (uVar3 != 0) {
param_2 = *(int **)(local_30 + 0x2c);
do {
if (iVar4 == *(int *)(*param_2 + 4)) break;
uVar7 = uVar7 + 1;
param_2 = param_2 + 1;
} while (uVar7 < uVar3);
}
if (uVar7 < uVar3) {
iVar4 = *(int *)(*(int *)(local_30 + 0x2c) + uVar7 * 4);
if ((DAT_00796344 < *(float *)(iVar8 + 0x14)) && (DAT_00796344 < *(float *)(iVar4 + 0x14))
) {
*(float *)(uVar6 * 0x2c + 0x20 + *piVar5) =
(*(float *)(iVar4 + 0x14) - *(float *)(iVar8 + 0x14)) * (float)param_3 +
*(float *)(iVar8 + 0x14);
}
if ((DAT_00796344 < *(float *)(iVar8 + 0x18)) && (DAT_00796344 < *(float *)(iVar4 + 0x18))
) {
*(float *)(uVar6 * 0x2c + 0x24 + *piVar5) =
(*(float *)(iVar4 + 0x18) - *(float *)(iVar8 + 0x18)) * (float)param_3 +
*(float *)(iVar8 + 0x18);
}
if ((DAT_00796344 <= *(float *)(iVar8 + 0x10)) &&
(DAT_00796344 <= *(float *)(iVar4 + 0x10))) {
*(float *)(uVar6 * 0x2c + 0x1c + *piVar5) =
(*(float *)(iVar4 + 0x10) - *(float *)(iVar8 + 0x10)) * (float)param_3 +
*(float *)(iVar8 + 0x10);
}
}
}
local_38 = local_38 + 1;
} while (local_38 < *(uint *)(local_34 + 0x34));
}
return 1;
}
// --- FUN_00502da0 at 0x00502DA0 (size: 22) ---
void __fastcall FUN_00502da0(int param_1)
{
FUN_00502970();
operator_delete__(*(void **)(param_1 + 0x18));
return;
}
// --- FUN_00502dc0 at 0x00502DC0 (size: 84) ---
void __fastcall FUN_00502dc0(int *param_1)
{
void *pvVar1;
uint uVar2;
uVar2 = 0;
if (param_1[2] != 0) {
do {
pvVar1 = *(void **)(*param_1 + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
FUN_00503cc0();
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < (uint)param_1[2]);
}
param_1[2] = 0;
param_1[1] = 0;
operator_delete__((void *)*param_1);
*param_1 = 0;
return;
}
// --- FUN_00502e20 at 0x00502E20 (size: 45) ---
int __fastcall FUN_00502e20(int param_1)
{
int iVar1;
int iVar2;
uint uVar3;
uVar3 = 0;
iVar2 = 4;
if (*(int *)(param_1 + 8) != 0) {
do {
iVar1 = FUN_00503c20();
iVar2 = iVar2 + iVar1;
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 8));
}
return iVar2;
}
// --- FUN_00502e50 at 0x00502E50 (size: 21) ---
void __fastcall FUN_00502e50(undefined4 *param_1)
{
FUN_00502dc0();
operator_delete__((void *)*param_1);
return;
}
// --- FUN_00502e70 at 0x00502E70 (size: 121) ---
void __fastcall FUN_00502e70(int *param_1)
{
int iVar1;
int iVar2;
undefined4 uVar3;
uint uVar4;
undefined4 uVar5;
uint local_18;
local_18 = 0;
if (param_1[2] != 0) {
do {
iVar1 = *(int *)(*param_1 + local_18 * 4);
if (*(int *)(iVar1 + 0xc) != 0) {
uVar4 = 0;
do {
iVar2 = *(int *)(*(int *)(iVar1 + 4) + uVar4 * 4);
if (iVar2 != DAT_00842550) {
uVar5 = 8;
uVar3 = FUN_004220b0(iVar2,0);
FUN_0041a4e0(uVar3,uVar5);
}
uVar4 = uVar4 + 1;
} while (uVar4 < *(uint *)(iVar1 + 0xc));
}
local_18 = local_18 + 1;
} while (local_18 < (uint)param_1[2]);
}
return;
}
// --- FUN_00502ef0 at 0x00502EF0 (size: 64) ---
undefined4 __thiscall FUN_00502ef0(int *param_1,undefined4 param_2)
{
uint uVar1;
int iVar2;
uVar1 = param_1[1];
if (uVar1 <= (uint)param_1[2]) {
if (uVar1 == 0) {
iVar2 = 8;
}
else {
iVar2 = uVar1 * 2;
}
iVar2 = FUN_00500570(iVar2);
if (iVar2 == 0) {
return 0;
}
}
*(undefined4 *)(*param_1 + param_1[2] * 4) = param_2;
param_1[2] = param_1[2] + 1;
return 1;
}
// --- FUN_00502f30 at 0x00502F30 (size: 7) ---
void FUN_00502f30(void)
{
FUN_005034d0();
return;
}
// --- FUN_00502f40 at 0x00502F40 (size: 16) ---
void __fastcall FUN_00502f40(undefined4 *param_1)
{
*param_1 = 0;
param_1[1] = 0;
param_1[2] = 0;
param_1[3] = 0;
return;
}
// --- FUN_00502f50 at 0x00502F50 (size: 45) ---
undefined4 __thiscall FUN_00502f50(int param_1,uint param_2,uint param_3)
{
int iVar1;
if (param_2 < *(uint *)(param_1 + 0xc)) {
iVar1 = *(int *)(*(int *)(param_1 + 4) + param_2 * 4);
if ((param_3 < *(uint *)(iVar1 + 0x10)) &&
(iVar1 = *(int *)(*(int *)(iVar1 + 8) + param_3 * 4), iVar1 != 0)) {
return *(undefined4 *)(iVar1 + 0x10);
}
}
return 0;
}
// --- FUN_00502f80 at 0x00502F80 (size: 26) ---
undefined4 __thiscall FUN_00502f80(int param_1,uint param_2)
{
if (param_2 < *(uint *)(param_1 + 0xc)) {
return *(undefined4 *)(*(int *)(*(int *)(param_1 + 4) + param_2 * 4) + 0x10);
}
return 0;
}
// --- FUN_00502fa0 at 0x00502FA0 (size: 45) ---
undefined4 __thiscall FUN_00502fa0(int param_1,uint param_2,uint param_3)
{
int iVar1;
if (param_2 < *(uint *)(param_1 + 0xc)) {
iVar1 = *(int *)(*(int *)(param_1 + 4) + param_2 * 4);
if ((param_3 < *(uint *)(iVar1 + 0x10)) &&
(iVar1 = *(int *)(*(int *)(iVar1 + 8) + param_3 * 4), iVar1 != 0)) {
return *(undefined4 *)(iVar1 + 0xc);
}
}
return 0;
}
// --- FUN_00502fd0 at 0x00502FD0 (size: 59) ---
void __thiscall FUN_00502fd0(int param_1,undefined4 *param_2,int param_3,int param_4,uint param_5)
{
int iVar1;
iVar1 = *(int *)(*(int *)(*(int *)(*(int *)(param_1 + 4) + param_3 * 4) + 8) + param_4 * 4);
if (param_5 < *(uint *)(iVar1 + 0xc)) {
*param_2 = *(undefined4 *)(*(int *)(iVar1 + 4) + param_5 * 4);
return;
}
*param_2 = DAT_008425b4;
return;
}
// --- FUN_00503010 at 0x00503010 (size: 51) ---
int * __fastcall FUN_00503010(int *param_1)
{
LONG *lpAddend;
lpAddend = (LONG *)(DAT_008ef11c + 4);
*param_1 = DAT_008ef11c;
InterlockedIncrement(lpAddend);
param_1[2] = 0;
param_1[3] = 0;
param_1[4] = 0;
*(undefined1 *)((int)param_1 + 6) = 0xff;
*(undefined1 *)((int)param_1 + 5) = 0xff;
*(undefined1 *)(param_1 + 1) = 0xff;
*(undefined1 *)((int)param_1 + 7) = 0xff;
return param_1;
}
// --- FUN_00503050 at 0x00503050 (size: 165) ---
void __fastcall FUN_00503050(undefined4 *param_1)
{
int *piVar1;
undefined4 *puVar2;
void *pvVar3;
LONG LVar4;
uint local_4;
local_4 = 0;
if (param_1[3] != 0) {
do {
piVar1 = *(int **)(param_1[1] + local_4 * 4);
if (piVar1 != (int *)0x0) {
piVar1[4] = 0;
piVar1[3] = 0;
operator_delete__((void *)piVar1[2]);
piVar1[2] = 0;
operator_delete__((void *)0x0);
puVar2 = (undefined4 *)*piVar1;
LVar4 = InterlockedDecrement(puVar2 + 1);
if ((LVar4 == 0) && (puVar2 != (undefined4 *)0x0)) {
(**(code **)*puVar2)(1);
}
operator_delete(piVar1);
}
local_4 = local_4 + 1;
} while (local_4 < (uint)param_1[3]);
}
param_1[3] = 0;
param_1[2] = 0;
operator_delete__((void *)param_1[1]);
param_1[1] = 0;
pvVar3 = (void *)*param_1;
if (pvVar3 != (void *)0x0) {
FUN_005037a0();
operator_delete(pvVar3);
}
*param_1 = 0;
return;
}
// --- FUN_00503100 at 0x00503100 (size: 65) ---
undefined4 __thiscall FUN_00503100(int param_1,undefined4 param_2)
{
uint uVar1;
int iVar2;
uVar1 = *(uint *)(param_1 + 8);
if (uVar1 <= *(uint *)(param_1 + 0xc)) {
if (uVar1 == 0) {
iVar2 = 8;
}
else {
iVar2 = uVar1 * 2;
}
iVar2 = FUN_00500570(iVar2);
if (iVar2 == 0) {
return 0;
}
}
*(undefined4 *)(*(int *)(param_1 + 4) + *(int *)(param_1 + 0xc) * 4) = param_2;
*(int *)(param_1 + 0xc) = *(int *)(param_1 + 0xc) + 1;
return 1;
}
// --- FUN_00503150 at 0x00503150 (size: 112) ---
int __fastcall FUN_00503150(int param_1)
{
uint uVar1;
int iVar2;
int iVar3;
uint uVar4;
int *piVar5;
int iVar6;
iVar2 = *(int *)(param_1 + 0xc);
iVar6 = 4;
if (iVar2 != 0) {
piVar5 = *(int **)(param_1 + 4);
do {
uVar1 = *(int *)(*(int *)*piVar5 + 8) - 1;
iVar3 = 0;
if (0xfffe < uVar1) {
iVar3 = 4;
}
uVar1 = iVar3 + 2 + uVar1;
uVar4 = uVar1 & 3;
if (uVar4 == 0) {
iVar3 = 0;
}
else {
iVar3 = 4 - uVar4;
}
iVar6 = iVar6 + iVar3 + 8 + ((int *)*piVar5)[4] * 4 + uVar1;
piVar5 = piVar5 + 1;
iVar2 = iVar2 + -1;
} while (iVar2 != 0);
}
iVar2 = FUN_005034f0();
return iVar2 + iVar6;
}
// --- FUN_005031c0 at 0x005031C0 (size: 22) ---
void __fastcall FUN_005031c0(int param_1)
{
FUN_00503050();
operator_delete__(*(void **)(param_1 + 4));
return;
}
// --- FUN_005031e0 at 0x005031E0 (size: 13) ---
void __fastcall FUN_005031e0(undefined4 *param_1)
{
*param_1 = 0;
param_1[1] = 0;
param_1[2] = 0;
return;
}
// --- FUN_005031f0 at 0x005031F0 (size: 84) ---
void __fastcall FUN_005031f0(int *param_1)
{
void *pvVar1;
uint uVar2;
uVar2 = 0;
if (param_1[2] != 0) {
do {
pvVar1 = *(void **)(*param_1 + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
FUN_00551de0();
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < (uint)param_1[2]);
}
param_1[2] = 0;
param_1[1] = 0;
operator_delete__((void *)*param_1);
*param_1 = 0;
return;
}
// --- FUN_00503250 at 0x00503250 (size: 67) ---
uint __fastcall FUN_00503250(int param_1)
{
int iVar1;
uint uVar2;
uint uVar3;
uVar3 = 0;
uVar2 = 4;
if (*(int *)(param_1 + 8) != 0) {
do {
iVar1 = FUN_00551f20();
uVar2 = uVar2 + iVar1;
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 8));
}
if ((uVar2 & 3) != 0) {
return (4 - (uVar2 & 3)) + uVar2;
}
return uVar2;
}
// --- FUN_005032a0 at 0x005032A0 (size: 110) ---
uint __thiscall FUN_005032a0(int param_1,int *param_2,uint *param_3)
{
uint uVar1;
uint uVar2;
uVar2 = *(uint *)(param_1 + 8);
if (3 < *param_3) {
*(uint *)*param_2 = uVar2;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar1 = 0;
if (uVar2 != 0) {
do {
FUN_00551e40(param_2,param_3);
uVar1 = uVar1 + 1;
} while (uVar1 < uVar2);
}
uVar2 = 0;
if (*(int *)(param_1 + 8) != 0) {
do {
FUN_00551f20();
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 8));
return *param_3;
}
return *param_3;
}
// --- FUN_00503310 at 0x00503310 (size: 21) ---
void __fastcall FUN_00503310(undefined4 *param_1)
{
FUN_005031f0();
operator_delete__((void *)*param_1);
return;
}
// --- FUN_00503330 at 0x00503330 (size: 75) ---
void __fastcall FUN_00503330(int *param_1)
{
int iVar1;
undefined4 uVar2;
uint uVar3;
undefined4 uVar4;
uVar3 = 0;
if (param_1[2] != 0) {
do {
iVar1 = **(int **)(*param_1 + uVar3 * 4);
if (iVar1 != DAT_0084260c) {
uVar4 = 0;
uVar2 = FUN_004220b0(iVar1,0);
FUN_0041a4e0(uVar2,uVar4);
}
uVar3 = uVar3 + 1;
} while (uVar3 < (uint)param_1[2]);
}
return;
}
// --- FUN_00503380 at 0x00503380 (size: 192) ---
undefined4 __thiscall FUN_00503380(int *param_1,int *param_2,uint *param_3)
{
uint uVar1;
uint *puVar2;
int iVar3;
undefined4 uVar4;
int *piVar5;
puVar2 = param_3;
piVar5 = param_2;
if (3 < *param_3) {
piVar5 = *(int **)*param_2;
*param_2 = (int)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
}
FUN_005031f0();
if (piVar5 != (int *)0x0) {
FUN_00500570(piVar5);
}
param_3 = (uint *)0x0;
if (piVar5 != (int *)0x0) {
do {
iVar3 = FUN_005df0f5(0x1c);
if (iVar3 == 0) {
uVar4 = 0;
}
else {
uVar4 = FUN_00551dc0();
}
iVar3 = FUN_00552510(param_2,puVar2);
if (iVar3 == 0) {
return 0;
}
uVar1 = param_1[1];
if ((uint)param_1[2] < uVar1) {
LAB_00503413:
*(undefined4 *)(*param_1 + param_1[2] * 4) = uVar4;
param_1[2] = param_1[2] + 1;
}
else {
if (uVar1 == 0) {
iVar3 = 8;
}
else {
iVar3 = uVar1 * 2;
}
iVar3 = FUN_00500570(iVar3);
if (iVar3 != 0) goto LAB_00503413;
}
param_3 = (uint *)((int)param_3 + 1);
} while (param_3 < piVar5);
}
return 1;
}
// --- FUN_00503440 at 0x00503440 (size: 122) ---
void __fastcall FUN_00503440(uint *param_1)
{
int *piVar1;
uint uVar2;
if (param_1[1] != 0) {
uVar2 = 0;
if (*param_1 != 0) {
do {
piVar1 = *(int **)(param_1[1] + uVar2 * 4);
if (piVar1 != (int *)0x0) {
if (*piVar1 != 0) {
operator_delete__((void *)(*piVar1 + -4));
}
*piVar1 = 0;
operator_delete(piVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *param_1);
}
operator_delete__((void *)param_1[1]);
param_1[1] = 0;
}
if ((void *)param_1[2] != (void *)0x0) {
operator_delete__((void *)param_1[2]);
param_1[2] = 0;
}
*param_1 = 0;
return;
}
// --- thunk_FUN_00503440 at 0x005034C0 (size: 5) ---
void __fastcall thunk_FUN_00503440(uint *param_1)
{
int *piVar1;
uint uVar2;
if (param_1[1] != 0) {
uVar2 = 0;
if (*param_1 != 0) {
do {
piVar1 = *(int **)(param_1[1] + uVar2 * 4);
if (piVar1 != (int *)0x0) {
if (*piVar1 != 0) {
operator_delete__((void *)(*piVar1 + -4));
}
*piVar1 = 0;
operator_delete(piVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *param_1);
}
operator_delete__((void *)param_1[1]);
param_1[1] = 0;
}
if ((void *)param_1[2] != (void *)0x0) {
operator_delete__((void *)param_1[2]);
param_1[2] = 0;
}
*param_1 = 0;
return;
}
// --- FUN_005034d0 at 0x005034D0 (size: 21) ---
void __fastcall FUN_005034d0(int *param_1)
{
if (*param_1 != 0) {
FUN_00500ce0();
return;
}
FUN_00504710();
return;
}
// --- FUN_005034f0 at 0x005034F0 (size: 29) ---
int __fastcall FUN_005034f0(int *param_1)
{
int iVar1;
if (*param_1 != 0) {
iVar1 = FUN_005009f0();
return iVar1 + 4;
}
iVar1 = FUN_00504400();
return iVar1 + 4;
}
// --- FUN_00503510 at 0x00503510 (size: 188) ---
uint __fastcall FUN_00503510(int param_1)
{
int *piVar1;
undefined4 uVar2;
uint uVar3;
uint uVar4;
uint uVar5;
int *piVar6;
piVar1 = *(int **)(param_1 + 0x10);
if (piVar1 == (int *)0x0) {
*(undefined4 *)(param_1 + 0xc) = 0x28;
uVar2 = thunk_FUN_005df0f5(0xa0);
*(undefined4 *)(param_1 + 0x10) = uVar2;
uVar3 = 0;
if (*(int *)(param_1 + 0xc) != 0) {
do {
*(undefined4 *)(*(int *)(param_1 + 0x10) + uVar3 * 4) = 0;
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0xc));
}
return 0;
}
uVar3 = *(uint *)(param_1 + 0xc);
uVar4 = 0;
piVar6 = piVar1;
if (uVar3 != 0) {
do {
if (*piVar6 == 0) {
return uVar4;
}
uVar4 = uVar4 + 1;
piVar6 = piVar6 + 1;
} while (uVar4 < *(uint *)(param_1 + 0xc));
}
uVar4 = uVar3 + 0x28;
uVar2 = thunk_FUN_005df0f5(uVar4 * 4);
*(undefined4 *)(param_1 + 0x10) = uVar2;
uVar5 = 0;
if (*(int *)(param_1 + 0xc) != 0) {
do {
*(int *)(*(int *)(param_1 + 0x10) + uVar5 * 4) = piVar1[uVar5];
uVar5 = uVar5 + 1;
} while (uVar5 < *(uint *)(param_1 + 0xc));
}
for (uVar5 = *(uint *)(param_1 + 0xc); uVar5 < uVar4; uVar5 = uVar5 + 1) {
*(undefined4 *)(*(int *)(param_1 + 0x10) + uVar5 * 4) = 0;
}
*(uint *)(param_1 + 0xc) = uVar4;
operator_delete__(piVar1);
return uVar3;
}
// --- FUN_005035e0 at 0x005035E0 (size: 17) ---
undefined4 __fastcall FUN_005035e0(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 4) == 0) {
return 0;
}
uVar1 = FUN_00504470();
return uVar1;
}
// --- FUN_00503600 at 0x00503600 (size: 111) ---
void __fastcall FUN_00503600(undefined4 *param_1)
{
void *pvVar1;
pvVar1 = (void *)*param_1;
if (pvVar1 != (void *)0x0) {
FUN_00501430();
operator_delete(pvVar1);
*param_1 = 0;
}
if (param_1[1] != 0) {
operator_delete(DAT_0084271c);
DAT_0084271c = (void *)0x0;
pvVar1 = (void *)param_1[1];
if (pvVar1 != (void *)0x0) {
FUN_00505330();
operator_delete(pvVar1);
}
param_1[1] = 0;
}
if ((void *)param_1[4] != (void *)0x0) {
operator_delete__((void *)param_1[4]);
param_1[4] = 0;
}
param_1[5] = 0;
param_1[3] = 0;
return;
}
// --- FUN_00503670 at 0x00503670 (size: 94) ---
uint __thiscall FUN_00503670(int *param_1,int *param_2,uint *param_3)
{
int iVar1;
iVar1 = *param_1;
if (3 < *param_3) {
*(uint *)*param_2 = (uint)(iVar1 != 0);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
if ((iVar1 != 0) == 0) {
FUN_00504b40(param_2,param_3);
}
else {
FUN_00500f20(param_2,param_3);
}
if (*param_1 != 0) {
FUN_005009f0();
return *param_3;
}
FUN_00504400();
return *param_3;
}
// --- FUN_005036d0 at 0x005036D0 (size: 156) ---
void __thiscall FUN_005036d0(undefined4 *param_1,undefined4 *param_2,uint *param_3)
{
int iVar1;
undefined4 uVar2;
uint *puVar3;
puVar3 = param_3;
if (3 < *param_3) {
puVar3 = *(uint **)*param_2;
*param_2 = (undefined4 *)*param_2 + 1;
*param_3 = *param_3 - 4;
}
if (puVar3 == (uint *)0x0) {
iVar1 = FUN_005df0f5(0x34);
if (iVar1 == 0) {
param_1[1] = 0;
FUN_00505010(param_2,param_3);
return;
}
uVar2 = FUN_00503fb0();
param_1[1] = uVar2;
FUN_00505010(param_2,param_3);
return;
}
iVar1 = FUN_005df0f5(0x18);
if (iVar1 == 0) {
*param_1 = 0;
FUN_00501320(param_2,param_3);
return;
}
uVar2 = FUN_00500680();
*param_1 = uVar2;
FUN_00501320(param_2,param_3);
return;
}
// --- FUN_00503770 at 0x00503770 (size: 44) ---
undefined4 * __thiscall FUN_00503770(int param_1,undefined4 *param_2,undefined4 param_3)
{
if (*(int *)(param_1 + 4) == 0) {
*param_2 = DAT_008426bc;
return param_2;
}
FUN_00504440(param_2,param_3);
return param_2;
}
// --- FUN_005037a0 at 0x005037A0 (size: 35) ---
void __fastcall FUN_005037a0(int param_1)
{
FUN_00503600();
if (*(undefined4 **)(param_1 + 8) != (undefined4 *)0x0) {
(**(code **)**(undefined4 **)(param_1 + 8))(1);
}
operator_delete__(*(void **)(param_1 + 0x1c));
return;
}
// --- FUN_005037d0 at 0x005037D0 (size: 82) ---
void __thiscall FUN_005037d0(int param_1,undefined4 param_2,undefined4 param_3)
{
undefined4 *puVar1;
uint uVar2;
undefined4 *puVar3;
puVar1 = (undefined4 *)FUN_005df0f5(0x10);
puVar3 = (undefined4 *)0x0;
if (puVar1 != (undefined4 *)0x0) {
puVar1[1] = 0;
puVar1[3] = param_2;
puVar1[2] = param_3;
*puVar1 = &PTR_LAB_007c78e0;
puVar3 = puVar1;
}
uVar2 = ((uint)puVar3[2] >> ((byte)*(undefined4 *)(param_1 + 8) & 0x1f) ^ puVar3[2]) &
*(uint *)(param_1 + 4);
puVar3[1] = *(undefined4 *)(*(int *)(param_1 + 0xc) + uVar2 * 4);
*(undefined4 **)(*(int *)(param_1 + 0xc) + uVar2 * 4) = puVar3;
return;
}
// --- FUN_00503830 at 0x00503830 (size: 171) ---
undefined4 * __fastcall FUN_00503830(undefined4 *param_1)
{
undefined4 *puVar1;
undefined4 uVar2;
uint uVar3;
uint uVar4;
*param_1 = 0;
param_1[1] = 0;
param_1[3] = 0;
param_1[4] = 0;
param_1[5] = 0;
param_1[7] = 0;
param_1[8] = 0;
param_1[9] = 0;
puVar1 = (undefined4 *)FUN_005df0f5(0x18);
if (puVar1 != (undefined4 *)0x0) {
*puVar1 = &PTR_FUN_007c7450;
puVar1[5] = 0;
uVar2 = thunk_FUN_005df0f5(0x40);
puVar1[3] = uVar2;
puVar1[4] = 0x10;
puVar1[2] = 8;
puVar1[1] = 0;
uVar3 = 1;
do {
uVar4 = puVar1[1] | uVar3;
uVar3 = uVar3 << 1;
puVar1[1] = uVar4;
} while ((uVar4 | uVar3) < (uint)puVar1[4]);
uVar3 = 0;
do {
*(undefined4 *)(puVar1[3] + uVar3 * 4) = 0;
uVar3 = uVar3 + 1;
} while (uVar3 < (uint)puVar1[4]);
*puVar1 = &PTR_FUN_007c7098;
param_1[2] = puVar1;
param_1[10] = 0;
param_1[6] = 0;
return param_1;
}
param_1[2] = 0;
param_1[10] = 0;
param_1[6] = 0;
return param_1;
}
// --- FUN_005038e0 at 0x005038E0 (size: 102) ---
undefined4 __thiscall FUN_005038e0(int param_1,undefined4 param_2,undefined4 param_3,int *param_4)
{
undefined4 *puVar1;
int iVar2;
undefined4 *puVar3;
puVar1 = (undefined4 *)FUN_005df0f5(0x10);
puVar3 = (undefined4 *)0x0;
if (puVar1 != (undefined4 *)0x0) {
*puVar1 = 0;
puVar1[1] = 0;
puVar1[2] = 0;
puVar1[3] = 0;
puVar3 = puVar1;
}
puVar3[2] = param_2;
*puVar3 = param_3;
iVar2 = FUN_00503510();
*param_4 = iVar2;
puVar3[1] = puVar3[1] + 1;
puVar3[3] = *param_4;
*(undefined4 *)(*(int *)(param_1 + 0x10) + *param_4 * 4) = param_2;
FUN_005037d0(puVar3,param_3);
*(int *)(param_1 + 0x14) = *(int *)(param_1 + 0x14) + 1;
return 1;
}
// --- FUN_00503950 at 0x00503950 (size: 267) ---
/* WARNING: Removing unreachable block (ram,0x00503a01) */
void __thiscall FUN_00503950(int *param_1,void *param_2)
{
int *piVar1;
int iVar2;
int iVar3;
uint uVar4;
void *pvVar5;
iVar2 = param_1[2];
if (iVar2 != 0) {
iVar3 = **(int **)(iVar2 + 0xc);
if (iVar3 == 0) {
FUN_004d8d00();
}
uVar4 = 0;
pvVar5 = param_2;
while( true ) {
if (iVar3 != 0) {
pvVar5 = *(void **)(iVar3 + 0xc);
}
if (*(int *)((int)pvVar5 + 8) == *(int *)(param_1[4] + (int)param_2 * 4)) break;
if ((iVar3 == 0) || (iVar3 = *(int *)(iVar3 + 4), iVar3 == 0)) {
do {
uVar4 = uVar4 + 1;
if (*(uint *)(iVar2 + 0x10) <= uVar4) {
return;
}
iVar3 = *(int *)(*(int *)(iVar2 + 0xc) + uVar4 * 4);
} while (iVar3 == 0);
}
}
piVar1 = (int *)((int)pvVar5 + 4);
*piVar1 = *piVar1 + -1;
if (*piVar1 == 0) {
*(undefined4 *)(param_1[4] + (int)param_2 * 4) = 0;
FUN_004f8040();
if (*param_1 == 0) {
if (param_1[1] != 0) {
FUN_00503e30(*(undefined4 *)((int)pvVar5 + 8));
}
}
else {
FUN_005004c0(*(undefined4 *)((int)pvVar5 + 8));
}
param_1[5] = param_1[5] + -1;
operator_delete(pvVar5);
}
}
return;
}
// --- FUN_00503a60 at 0x00503A60 (size: 30) ---
void * __thiscall FUN_00503a60(void *param_1,byte param_2)
{
FUN_00503a80();
if ((param_2 & 1) != 0) {
operator_delete(param_1);
}
return param_1;
}
// --- FUN_00503a80 at 0x00503A80 (size: 79) ---
void __fastcall FUN_00503a80(undefined4 *param_1)
{
int local_4;
*param_1 = &PTR_FUN_007c7098;
FUN_005143c0(param_1);
if (local_4 == 0) {
do {
FUN_004f8040();
} while( true );
}
*param_1 = &PTR_FUN_007c7450;
if (param_1[5] == 0) {
operator_delete__((void *)param_1[3]);
}
return;
}
// --- FUN_00503ad0 at 0x00503AD0 (size: 326) ---
undefined4 __thiscall
FUN_00503ad0(int *param_1,undefined4 param_2,undefined4 param_3,undefined4 *param_4,
undefined4 *param_5,undefined4 *param_6,undefined4 param_7,undefined4 param_8)
{
undefined4 *puVar1;
undefined4 uVar2;
int iVar3;
undefined4 uVar4;
undefined1 local_14 [20];
puVar1 = param_5;
if (*param_1 != 0) {
uVar2 = FUN_00500d90(param_2,param_3,param_5,param_6,param_7,local_14,&param_5,param_8);
iVar3 = FUN_00523210(uVar2,&param_6);
if (iVar3 != 0) {
param_6[1] = param_6[1] + 1;
*param_4 = param_6[3];
return 1;
}
uVar4 = FUN_00500ea0(uVar2,*puVar1,local_14,param_5);
uVar2 = FUN_005038e0(uVar4,uVar2,param_4);
return uVar2;
}
if (param_1[1] == 0) {
return 0;
}
uVar2 = *param_6;
*param_5 = 0;
iVar3 = FUN_00523210(uVar2,&param_6);
if (iVar3 != 0) {
param_6[1] = param_6[1] + 1;
*param_4 = param_6[3];
FUN_00401030(local_14,4,5,FUN_00695670);
return 1;
}
uVar4 = FUN_00505410(uVar2,param_7);
uVar2 = FUN_005038e0(uVar4,uVar2,param_4);
FUN_00401030(local_14,4,5,FUN_00695670);
return uVar2;
}
// --- FUN_00503c20 at 0x00503C20 (size: 11) ---
int __fastcall FUN_00503c20(int param_1)
{
return *(int *)(param_1 + 0xc) * 4 + 8;
}
// --- FUN_00503c30 at 0x00503C30 (size: 88) ---
uint __thiscall FUN_00503c30(int param_1,int *param_2,uint *param_3)
{
undefined4 *puVar1;
uint uVar2;
puVar1 = (undefined4 *)*param_2;
if (3 < *param_3) {
*puVar1 = *(undefined4 *)(param_1 + 0xc);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar2 = 0;
if (*(int *)(param_1 + 0xc) != 0) {
do {
if (3 < *param_3) {
*(undefined4 *)*param_2 = *(undefined4 *)(*(int *)(param_1 + 4) + uVar2 * 4);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0xc));
}
uVar2 = *param_3 + (*param_2 - (int)puVar1);
*param_3 = uVar2;
return uVar2;
}
// --- FUN_00503c90 at 0x00503C90 (size: 40) ---
undefined4 * __fastcall FUN_00503c90(undefined4 *param_1)
{
LONG *lpAddend;
lpAddend = (LONG *)(PTR_DAT_00818344 + -0x10);
*param_1 = PTR_DAT_00818344;
InterlockedIncrement(lpAddend);
param_1[1] = 0;
param_1[2] = 0;
param_1[3] = 0;
param_1[4] = 0;
return param_1;
}
// --- FUN_00503cc0 at 0x00503CC0 (size: 81) ---
void __fastcall FUN_00503cc0(int *param_1)
{
LONG LVar1;
undefined4 *puVar2;
FUN_004158b0();
if (((param_1[2] & 0x80000000U) == 0x80000000) && (param_1[1] != 0)) {
operator_delete__((void *)(param_1[1] + -4));
}
puVar2 = (undefined4 *)(*param_1 + -0x14);
LVar1 = InterlockedDecrement((LONG *)(*param_1 + -0x10));
if ((LVar1 == 0) && (puVar2 != (undefined4 *)0x0)) {
(**(code **)*puVar2)(1);
}
return;
}
// --- FUN_00503d20 at 0x00503D20 (size: 267) ---
undefined4 __thiscall FUN_00503d20(int param_1,undefined4 *param_2,uint *param_3)
{
int iVar1;
char cVar2;
uint uVar3;
uint *puVar4;
uint *puVar5;
uint uVar6;
puVar5 = param_3;
if (3 < *param_3) {
puVar5 = *(uint **)*param_2;
*param_2 = (undefined4 *)*param_2 + 1;
*param_3 = *param_3 - 4;
}
FUN_004158b0();
if (puVar5 != (uint *)0x0) {
FUN_00415910(puVar5);
puVar4 = param_3;
for (; puVar5 != (uint *)0x0; puVar5 = (uint *)((int)puVar5 + -1)) {
if (3 < *param_3) {
puVar4 = *(uint **)*param_2;
*param_2 = (undefined4 *)*param_2 + 1;
*param_3 = *param_3 - 4;
}
uVar3 = *(uint *)(param_1 + 8) & 0x7fffffff;
if (*(uint *)(param_1 + 0xc) < uVar3) {
LAB_00503e0a:
*(uint **)(*(int *)(param_1 + 4) + *(int *)(param_1 + 0xc) * 4) = puVar4;
*(int *)(param_1 + 0xc) = *(int *)(param_1 + 0xc) + 1;
}
else {
uVar3 = uVar3 + 1;
if (uVar3 < 9) {
uVar3 = 8;
}
else if (uVar3 < 0x4001) {
iVar1 = 0x1f;
if (uVar3 != 0) {
for (; uVar3 >> iVar1 == 0; iVar1 = iVar1 + -1) {
}
}
uVar6 = 1 << ((byte)iVar1 & 0x1f);
if (uVar6 < uVar3) {
uVar3 = uVar6 * 2;
}
}
else if ((uVar3 & 0x3fff) != 0) {
uVar3 = uVar3 + (0x4000 - (uVar3 & 0x3fff));
}
cVar2 = FUN_00415910(uVar3);
if (cVar2 != '\0') goto LAB_00503e0a;
}
}
}
return 1;
}
// --- FUN_00503e30 at 0x00503E30 (size: 18) ---
void FUN_00503e30(int param_1)
{
if (param_1 != 0) {
FUN_00536c10(param_1);
}
return;
}
// --- FUN_00503e50 at 0x00503E50 (size: 209) ---
undefined4 FUN_00503e50(uint param_1,undefined4 *param_2,uint *param_3)
{
uint uVar1;
uVar1 = (uint)((param_1 & 0xc000000) != 0);
if ((param_1 & 0x3000000) != 0) {
uVar1 = uVar1 | 2;
}
if ((param_1 & 0xc00000) != 0) {
uVar1 = uVar1 | 4;
}
if ((param_1 & 0x300000) != 0) {
uVar1 = uVar1 | 8;
}
*param_2 = 0;
*param_3 = 0;
param_3[1] = 0;
switch(uVar1) {
case 0:
goto switchD_00503ea8_caseD_0;
default:
*param_3 = uVar1;
switchD_00503ea8_caseD_0:
return 1;
case 7:
*param_3 = 3;
param_3[1] = 6;
return 1;
case 0xb:
*param_3 = 9;
param_3[1] = 3;
return 1;
case 0xd:
*param_3 = 9;
param_3[1] = 0xc;
return 1;
case 0xe:
*param_3 = 6;
param_3[1] = 0xc;
return 1;
case 0xf:
*param_2 = 1;
return 1;
}
}
// --- FUN_00503f50 at 0x00503F50 (size: 29) ---
void FUN_00503f50(undefined4 param_1)
{
undefined4 uVar1;
uVar1 = FUN_004220b0(param_1,0xb);
FUN_00415430(uVar1);
return;
}
// --- FUN_00503f70 at 0x00503F70 (size: 55) ---
bool __fastcall FUN_00503f70(int *param_1)
{
undefined4 uVar1;
int iVar2;
if (*param_1 != DAT_00842770) {
uVar1 = FUN_004220b0(*param_1,0xb);
iVar2 = FUN_00415430(uVar1);
param_1[1] = iVar2;
}
return param_1[1] != 0;
}
// --- FUN_00503fb0 at 0x00503FB0 (size: 47) ---
void __fastcall FUN_00503fb0(undefined4 *param_1)
{
*param_1 = 0x10;
param_1[1] = 0;
param_1[2] = 0;
param_1[3] = 0;
param_1[4] = 0;
param_1[5] = 0;
param_1[6] = 0;
param_1[7] = 0;
param_1[8] = 0;
param_1[9] = 0;
param_1[10] = 0;
param_1[0xb] = 0;
param_1[0xc] = 0;
return;
}
// --- FUN_00503fe0 at 0x00503FE0 (size: 124) ---
undefined4 FUN_00503fe0(undefined4 param_1,undefined4 param_2,int *param_3)
{
undefined4 uVar1;
int iVar2;
iVar2 = param_3[1];
if (iVar2 == 0) {
if (*param_3 != DAT_00842770) {
uVar1 = FUN_004220b0(*param_3,0xb);
iVar2 = FUN_00415430(uVar1);
param_3[1] = iVar2;
}
iVar2 = param_3[1];
if (iVar2 == 0) {
FUN_00540030(param_1,param_2,param_2,0,1);
return 0;
}
}
FUN_00540030(param_1,param_2,param_2,iVar2,param_3[3]);
return 1;
}
// --- FUN_00504060 at 0x00504060 (size: 256) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __thiscall FUN_00504060(int param_1,uint param_2,int *param_3,uint *param_4,int param_5)
{
uint uVar1;
float fVar2;
float fVar3;
int iVar4;
uint uVar5;
undefined4 uVar6;
uint uVar7;
uint uVar8;
iVar4 = param_5 * 0x523aa99e + -0x51c9e74a;
uVar1 = *(uint *)(param_1 + 0x24);
fVar2 = (float)iVar4;
if (iVar4 < 0) {
fVar2 = fVar2 + _DAT_0079920c;
}
fVar3 = (float)(int)uVar1;
if ((int)uVar1 < 0) {
fVar3 = fVar3 + _DAT_0079920c;
}
floor((double)(fVar3 * fVar2 * _DAT_007c6f10));
iVar4 = FUN_005df4c4();
uVar8 = 0;
if (*(int *)(param_1 + 0x24) != 0) {
do {
*param_3 = *(int *)(*(int *)(param_1 + 0x1c) + ((uVar8 + iVar4) % uVar1) * 4);
*param_4 = 0;
uVar5 = *(uint *)*param_3;
uVar7 = 0;
do {
if (uVar5 == param_2) {
*param_4 = uVar7;
iVar4 = *param_3;
if ((*(int *)(iVar4 + 8) == 0) && (*(int *)(iVar4 + 4) != DAT_00842770)) {
FUN_004220b0(*(int *)(iVar4 + 4),0xb);
uVar6 = FUN_00415430();
*(undefined4 *)(iVar4 + 8) = uVar6;
}
return 1;
}
uVar5 = uVar5 * 2;
if (0xf < uVar5) {
uVar5 = uVar5 - 0xf;
}
uVar7 = uVar7 + 1;
} while (uVar7 < 4);
uVar8 = uVar8 + 1;
} while (uVar8 < *(uint *)(param_1 + 0x24));
}
*param_3 = 0;
return 0;
}
// --- FUN_00504160 at 0x00504160 (size: 447) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __thiscall FUN_00504160(int param_1,uint param_2,int *param_3,uint *param_4,int param_5)
{
float fVar1;
float fVar2;
uint uVar3;
undefined4 uVar4;
int iVar5;
uint uVar6;
if ((((param_2 == 1) || (param_2 == 2)) || (param_2 == 4)) || (param_2 == 8)) {
fVar1 = (float)*(int *)(param_1 + 0xc);
if (*(int *)(param_1 + 0xc) < 0) {
fVar1 = fVar1 + _DAT_0079920c;
}
iVar5 = param_5 * 0x523aa99e + -0x51c9e74a;
fVar2 = (float)iVar5;
if (iVar5 < 0) {
fVar2 = fVar2 + _DAT_0079920c;
}
floor((double)(fVar2 * _DAT_007c6f10 * fVar1));
iVar5 = FUN_005df4c4();
fVar2 = (float)iVar5;
if (iVar5 < 0) {
fVar2 = fVar2 + _DAT_0079920c;
}
if (fVar1 <= fVar2) {
iVar5 = 0;
}
*param_3 = *(int *)(*(int *)(param_1 + 4) + iVar5 * 4);
*param_4 = 0;
uVar3 = *(uint *)*param_3;
uVar6 = 0;
while (uVar3 != param_2) {
uVar3 = uVar3 * 2;
if (0xf < uVar3) {
uVar3 = uVar3 - 0xf;
}
uVar6 = uVar6 + 1;
if (3 < uVar6) {
return 0;
}
}
}
else {
fVar1 = (float)*(int *)(param_1 + 0x18);
if (*(int *)(param_1 + 0x18) < 0) {
fVar1 = fVar1 + _DAT_0079920c;
}
iVar5 = param_5 * 0x523aa99e + -0x51c9e74a;
fVar2 = (float)iVar5;
if (iVar5 < 0) {
fVar2 = fVar2 + _DAT_0079920c;
}
floor((double)(fVar2 * _DAT_007c6f10 * fVar1));
iVar5 = FUN_005df4c4();
fVar2 = (float)iVar5;
if (iVar5 < 0) {
fVar2 = fVar2 + _DAT_0079920c;
}
if (fVar1 <= fVar2) {
iVar5 = 0;
}
*param_3 = *(int *)(*(int *)(param_1 + 0x10) + iVar5 * 4);
*param_4 = 0;
uVar3 = *(uint *)*param_3;
uVar6 = 0;
while (uVar3 != param_2) {
uVar3 = uVar3 * 2;
if (0xf < uVar3) {
uVar3 = uVar3 - 0xf;
}
uVar6 = uVar6 + 1;
if (3 < uVar6) {
return 0;
}
}
}
*param_4 = uVar6;
iVar5 = *param_3;
if ((*(int *)(iVar5 + 8) == 0) && (*(int *)(iVar5 + 4) != DAT_00842770)) {
FUN_004220b0(*(int *)(iVar5 + 4),0xb);
uVar4 = FUN_00415430();
*(undefined4 *)(iVar5 + 8) = uVar4;
}
return 1;
}
// --- FUN_00504320 at 0x00504320 (size: 128) ---
undefined4
FUN_00504320(undefined4 param_1,undefined4 param_2,int param_3,undefined4 param_4,int param_5)
{
int iVar1;
if (param_3 == 0) {
return 0;
}
if (*(int *)(param_5 + 4) != 0) {
FUN_0053f5d0(param_1,param_2,param_2,*(int *)(param_5 + 4),*(undefined4 *)(param_5 + 0xc),
param_3,param_4);
return 1;
}
iVar1 = FUN_00503f70();
if (iVar1 != 0) {
FUN_0053f5d0(param_1,param_2,param_2,*(undefined4 *)(param_5 + 4),*(undefined4 *)(param_5 + 0xc)
,param_3,param_4);
return 1;
}
return 0;
}
// --- FUN_005043a0 at 0x005043A0 (size: 82) ---
undefined4 __thiscall FUN_005043a0(int param_1,int param_2)
{
uint uVar1;
uint uVar2;
undefined4 *puVar3;
uVar1 = *(uint *)(param_1 + 0x30);
uVar2 = 0;
if (uVar1 != 0) {
puVar3 = *(undefined4 **)(param_1 + 0x28);
do {
if (param_2 == *(int *)*puVar3) {
return **(undefined4 **)((*(undefined4 **)(param_1 + 0x28))[uVar2] + 4);
}
uVar2 = uVar2 + 1;
puVar3 = puVar3 + 1;
} while (uVar2 < uVar1);
}
if (uVar1 != 0) {
return **(undefined4 **)(**(int **)(param_1 + 0x28) + 4);
}
return 0;
}
// --- FUN_00504400 at 0x00504400 (size: 61) ---
int __fastcall FUN_00504400(int param_1)
{
int iVar1;
iVar1 = 8;
if (*(int *)(param_1 + 0xc) != 0) {
iVar1 = *(int *)(param_1 + 0xc) * 8 + 8;
}
iVar1 = iVar1 + 4;
if (*(int *)(param_1 + 0x18) != 0) {
iVar1 = iVar1 + *(int *)(param_1 + 0x18) * 8;
}
iVar1 = iVar1 + 4;
if (*(int *)(param_1 + 0x24) != 0) {
iVar1 = iVar1 + *(int *)(param_1 + 0x24) * 8;
}
iVar1 = iVar1 + 4;
if (*(int *)(param_1 + 0x30) != 0) {
iVar1 = iVar1 + *(int *)(param_1 + 0x30) * 0x2c;
}
return iVar1;
}
// --- FUN_00504440 at 0x00504440 (size: 47) ---
void __thiscall FUN_00504440(int param_1,undefined4 *param_2,uint param_3)
{
if (param_3 < *(uint *)(param_1 + 0x30)) {
*param_2 = *(undefined4 *)
(**(int **)(*(int *)(*(int *)(param_1 + 0x28) + param_3 * 4) + 4) + 0x2c);
return;
}
*param_2 = DAT_00842770;
return;
}
// --- FUN_00504470 at 0x00504470 (size: 31) ---
undefined4 __thiscall FUN_00504470(int param_1,uint param_2)
{
if (param_2 < *(uint *)(param_1 + 0x30)) {
return *(undefined4 *)(**(int **)(*(int *)(*(int *)(param_1 + 0x28) + param_2 * 4) + 4) + 0x28);
}
return 0;
}
// --- FUN_00504490 at 0x00504490 (size: 270) ---
uint __thiscall FUN_00504490(undefined4 *param_1,int *param_2,uint *param_3)
{
uint uVar1;
if (3 < *param_3) {
*(undefined4 *)*param_2 = *param_1;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[3];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[4];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[5];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[6];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[7];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[8];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[9];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[10];
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
*(undefined4 *)*param_2 = param_1[0xb];
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
}
}
}
}
}
}
}
}
return *param_3;
}
// --- FUN_005045a0 at 0x005045A0 (size: 272) ---
undefined4 __thiscall FUN_005045a0(undefined4 *param_1,int *param_2,uint *param_3)
{
undefined4 uVar1;
uint uVar2;
if (3 < *param_3) {
uVar1 = *(undefined4 *)*param_2;
*param_2 = (int)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
*param_1 = uVar1;
if (3 < *param_3) {
param_1[3] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar2 = *param_3;
*param_3 = uVar2 - 4;
if (3 < uVar2 - 4) {
param_1[4] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar2 = *param_3;
*param_3 = uVar2 - 4;
if (3 < uVar2 - 4) {
param_1[5] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar2 = *param_3;
*param_3 = uVar2 - 4;
if (3 < uVar2 - 4) {
param_1[6] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar2 = *param_3;
*param_3 = uVar2 - 4;
if (3 < uVar2 - 4) {
param_1[7] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar2 = *param_3;
*param_3 = uVar2 - 4;
if (3 < uVar2 - 4) {
param_1[8] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar2 = *param_3;
*param_3 = uVar2 - 4;
if (3 < uVar2 - 4) {
param_1[9] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar2 = *param_3;
*param_3 = uVar2 - 4;
if (3 < uVar2 - 4) {
param_1[10] = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar2 = *param_3;
*param_3 = uVar2 - 4;
if (3 < uVar2 - 4) {
uVar1 = *(undefined4 *)*param_2;
*param_2 = (int)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
param_1[0xb] = uVar1;
}
}
}
}
}
}
}
}
}
}
return 1;
}
// --- FUN_005046b0 at 0x005046B0 (size: 93) ---
void __fastcall FUN_005046b0(int param_1)
{
void *pvVar1;
uint uVar2;
uVar2 = 0;
if (*(int *)(param_1 + 0xc) != 0) {
do {
pvVar1 = *(void **)(*(int *)(param_1 + 4) + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
if (*(int **)((int)pvVar1 + 4) != (int *)0x0) {
(**(code **)(**(int **)((int)pvVar1 + 4) + 0x14))();
*(undefined4 *)((int)pvVar1 + 4) = 0;
}
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0xc));
}
*(undefined4 *)(param_1 + 0xc) = 0;
*(undefined4 *)(param_1 + 8) = 0;
operator_delete__(*(void **)(param_1 + 4));
*(undefined4 *)(param_1 + 4) = 0;
operator_delete__((void *)0x0);
return;
}
// --- FUN_00504710 at 0x00504710 (size: 261) ---
void __fastcall FUN_00504710(int param_1)
{
undefined4 *puVar1;
undefined4 uVar2;
uint uVar3;
undefined4 uVar4;
if (*(int *)(param_1 + 0xc) != 0) {
uVar3 = 0;
do {
uVar4 = 8;
uVar2 = FUN_004220b0(*(undefined4 *)(*(int *)(*(int *)(param_1 + 4) + uVar3 * 4) + 4),0);
FUN_0041a4e0(uVar2,uVar4);
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0xc));
}
uVar3 = 0;
if (*(int *)(param_1 + 0x18) != 0) {
do {
uVar4 = 8;
uVar2 = FUN_004220b0(*(undefined4 *)(*(int *)(*(int *)(param_1 + 0x10) + uVar3 * 4) + 4),0);
FUN_0041a4e0(uVar2,uVar4);
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0x18));
}
uVar3 = 0;
if (*(int *)(param_1 + 0x24) != 0) {
do {
uVar4 = 8;
uVar2 = FUN_004220b0(*(undefined4 *)(*(int *)(*(int *)(param_1 + 0x1c) + uVar3 * 4) + 4),0);
FUN_0041a4e0(uVar2,uVar4);
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0x24));
}
uVar3 = 0;
if (*(int *)(param_1 + 0x30) != 0) {
do {
puVar1 = (undefined4 *)**(int **)(*(int *)(*(int *)(param_1 + 0x28) + uVar3 * 4) + 4);
uVar4 = 8;
uVar2 = FUN_004220b0(*puVar1,0);
FUN_0041a4e0(uVar2,uVar4);
uVar4 = 8;
uVar2 = FUN_004220b0(puVar1[0xb],0);
FUN_0041a4e0(uVar2,uVar4);
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0x30));
}
return;
}
// --- FUN_00504820 at 0x00504820 (size: 790) ---
undefined4 __thiscall FUN_00504820(int param_1,uint param_2,undefined4 *param_3,uint *param_4)
{
undefined4 *puVar1;
uint uVar2;
undefined4 uVar3;
int iVar4;
byte bVar5;
uint uVar6;
undefined4 *puVar7;
uint uVar8;
undefined4 *puVar9;
uint local_10 [4];
local_10[0] = param_2 >> 0xf & 0x1f;
local_10[1] = param_2 >> 10 & 0x1f;
local_10[2] = param_2 >> 5 & 0x1f;
local_10[3] = param_2 & 0x1f;
uVar8 = 0;
do {
uVar2 = uVar8 + 1;
if (uVar8 < 3) {
uVar6 = uVar2;
do {
if (local_10[uVar8] == local_10[uVar6]) {
puVar7 = (undefined4 *)local_10[uVar8];
uVar8 = *(uint *)(param_1 + 0x30);
uVar2 = 0;
if (uVar8 == 0) goto LAB_005048e1;
puVar9 = *(undefined4 **)(param_1 + 0x28);
goto LAB_005048d0;
}
uVar6 = uVar6 + 1;
} while (uVar6 < 4);
}
uVar8 = uVar2;
} while (uVar2 < 4);
uVar8 = *(uint *)(param_1 + 0x30);
uVar2 = 0;
if (uVar8 != 0) {
puVar7 = *(undefined4 **)(param_1 + 0x28);
do {
if (local_10[0] == *(uint *)*puVar7) {
iVar4 = (*(undefined4 **)(param_1 + 0x28))[uVar2];
goto LAB_00504a46;
}
uVar2 = uVar2 + 1;
puVar7 = puVar7 + 1;
} while (uVar2 < uVar8);
}
if (uVar8 == 0) {
uVar3 = 0;
}
else {
iVar4 = **(int **)(param_1 + 0x28);
LAB_00504a46:
uVar3 = **(undefined4 **)(iVar4 + 4);
}
*param_3 = uVar3;
uVar8 = *(uint *)(param_1 + 0x30);
uVar2 = 0;
if (uVar8 != 0) {
puVar7 = *(undefined4 **)(param_1 + 0x28);
do {
if (local_10[1] == *(uint *)*puVar7) {
iVar4 = (*(undefined4 **)(param_1 + 0x28))[uVar2];
goto LAB_00504a80;
}
uVar2 = uVar2 + 1;
puVar7 = puVar7 + 1;
} while (uVar2 < uVar8);
}
if (uVar8 == 0) {
uVar3 = 0;
}
else {
iVar4 = **(int **)(param_1 + 0x28);
LAB_00504a80:
uVar3 = **(undefined4 **)(iVar4 + 4);
}
param_3[1] = uVar3;
uVar8 = *(uint *)(param_1 + 0x30);
uVar2 = 0;
if (uVar8 != 0) {
puVar7 = *(undefined4 **)(param_1 + 0x28);
do {
if (local_10[2] == *(uint *)*puVar7) {
iVar4 = (*(undefined4 **)(param_1 + 0x28))[uVar2];
goto LAB_00504ac4;
}
uVar2 = uVar2 + 1;
puVar7 = puVar7 + 1;
} while (uVar2 < uVar8);
}
if (uVar8 == 0) {
uVar3 = 0;
}
else {
iVar4 = **(int **)(param_1 + 0x28);
LAB_00504ac4:
uVar3 = **(undefined4 **)(iVar4 + 4);
}
param_3[2] = uVar3;
uVar8 = *(uint *)(param_1 + 0x30);
uVar2 = 0;
if (uVar8 != 0) {
puVar7 = *(undefined4 **)(param_1 + 0x28);
do {
if ((param_2 & 0x1f) == *(uint *)*puVar7) {
iVar4 = (*(undefined4 **)(param_1 + 0x28))[uVar2];
goto LAB_00504b03;
}
uVar2 = uVar2 + 1;
puVar7 = puVar7 + 1;
} while (uVar2 < uVar8);
}
if (uVar8 == 0) {
uVar3 = 0;
}
else {
iVar4 = **(int **)(param_1 + 0x28);
LAB_00504b03:
uVar3 = **(undefined4 **)(iVar4 + 4);
}
param_3[3] = uVar3;
*param_4 = 2;
param_4[1] = 4;
param_4[2] = 8;
return 1;
while( true ) {
uVar2 = uVar2 + 1;
puVar9 = puVar9 + 1;
if (uVar8 <= uVar2) break;
LAB_005048d0:
if (puVar7 == *(undefined4 **)*puVar9) {
iVar4 = (*(undefined4 **)(param_1 + 0x28))[uVar2];
goto LAB_005048f1;
}
}
LAB_005048e1:
if (uVar8 == 0) {
uVar3 = 0;
}
else {
iVar4 = **(int **)(param_1 + 0x28);
LAB_005048f1:
uVar3 = **(undefined4 **)(iVar4 + 4);
}
uVar8 = 0;
*param_3 = uVar3;
*param_4 = 0;
param_4[1] = 0;
param_4[2] = 0;
puVar9 = param_3;
do {
puVar1 = (undefined4 *)local_10[uVar8];
if (puVar1 != puVar7) {
bVar5 = (byte)uVar8;
if (*param_4 != 0) {
if ((undefined4 *)local_10[uVar8] == puVar9) {
if (uVar8 == 1) {
uVar2 = *param_4;
}
else {
if (uVar8 != 2) {
if ((uVar8 == 3) && (uVar2 = *param_4, uVar2 == 4)) goto LAB_005049e6;
goto LAB_0050499f;
}
uVar2 = *param_4;
}
if (uVar2 == uVar8) {
LAB_005049e6:
*param_4 = (1 << (bVar5 & 0x1f)) + uVar2;
return 1;
}
}
LAB_0050499f:
uVar2 = *(uint *)(param_1 + 0x30);
uVar6 = 0;
if (uVar2 == 0) goto LAB_005049c9;
puVar7 = *(undefined4 **)(param_1 + 0x28);
break;
}
uVar6 = 0;
*param_4 = 1 << (bVar5 & 0x1f);
uVar2 = *(uint *)(param_1 + 0x30);
if (uVar2 != 0) {
puVar9 = *(undefined4 **)(param_1 + 0x28);
do {
if (puVar1 == *(undefined4 **)*puVar9) {
uVar3 = **(undefined4 **)((*(undefined4 **)(param_1 + 0x28))[uVar6] + 4);
goto LAB_00504972;
}
uVar6 = uVar6 + 1;
puVar9 = puVar9 + 1;
} while (uVar6 < uVar2);
}
if (uVar2 == 0) {
uVar3 = 0;
}
else {
uVar3 = **(undefined4 **)(**(int **)(param_1 + 0x28) + 4);
}
LAB_00504972:
param_3[1] = uVar3;
puVar9 = puVar1;
}
uVar8 = uVar8 + 1;
if (3 < uVar8) {
return 1;
}
} while( true );
while( true ) {
uVar6 = uVar6 + 1;
puVar7 = puVar7 + 1;
if (uVar2 <= uVar6) break;
if (local_10[uVar8] == *(uint *)*puVar7) {
uVar3 = **(undefined4 **)((*(undefined4 **)(param_1 + 0x28))[uVar6] + 4);
goto LAB_00504a18;
}
}
LAB_005049c9:
if (uVar2 == 0) {
uVar3 = 0;
}
else {
uVar3 = **(undefined4 **)(**(int **)(param_1 + 0x28) + 4);
}
LAB_00504a18:
param_3[2] = uVar3;
param_4[1] = 1 << (bVar5 & 0x1f);
return 1;
}
// --- FUN_00504b40 at 0x00504B40 (size: 370) ---
uint __thiscall FUN_00504b40(undefined4 *param_1,int *param_2,uint *param_3)
{
uint uVar1;
undefined4 *puVar2;
uint uVar3;
uint uVar4;
if (3 < *param_3) {
*(undefined4 *)*param_2 = *param_1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar1 = param_1[3];
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar4 = 0;
if (uVar1 != 0) {
do {
puVar2 = *(undefined4 **)(param_1[1] + uVar4 * 4);
if (3 < *param_3) {
*(undefined4 *)*param_2 = *puVar2;
*param_2 = *param_2 + 4;
uVar3 = *param_3;
*param_3 = uVar3 - 4;
if (3 < uVar3 - 4) {
*(undefined4 *)*param_2 = puVar2[1];
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
uVar4 = uVar4 + 1;
} while (uVar4 < uVar1);
}
uVar1 = param_1[6];
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar4 = 0;
if (uVar1 != 0) {
do {
puVar2 = *(undefined4 **)(param_1[4] + uVar4 * 4);
if (3 < *param_3) {
*(undefined4 *)*param_2 = *puVar2;
*param_2 = *param_2 + 4;
uVar3 = *param_3;
*param_3 = uVar3 - 4;
if (3 < uVar3 - 4) {
*(undefined4 *)*param_2 = puVar2[1];
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
uVar4 = uVar4 + 1;
} while (uVar4 < uVar1);
}
uVar1 = param_1[9];
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar4 = 0;
if (uVar1 != 0) {
do {
puVar2 = *(undefined4 **)(param_1[7] + uVar4 * 4);
if (3 < *param_3) {
*(undefined4 *)*param_2 = *puVar2;
*param_2 = *param_2 + 4;
uVar3 = *param_3;
*param_3 = uVar3 - 4;
if (3 < uVar3 - 4) {
*(undefined4 *)*param_2 = puVar2[1];
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
}
uVar4 = uVar4 + 1;
} while (uVar4 < uVar1);
}
uVar1 = param_1[0xc];
if (3 < *param_3) {
*(uint *)*param_2 = uVar1;
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
uVar4 = 0;
if (uVar1 != 0) {
do {
if (3 < *param_3) {
*(undefined4 *)*param_2 = **(undefined4 **)(param_1[10] + uVar4 * 4);
*param_2 = *param_2 + 4;
*param_3 = *param_3 - 4;
}
FUN_00504490(param_2,param_3);
uVar4 = uVar4 + 1;
} while (uVar4 < uVar1);
}
return *param_3;
}
// --- FUN_00504cc0 at 0x00504CC0 (size: 188) ---
undefined4 __thiscall FUN_00504cc0(undefined4 *param_1,undefined4 *param_2,uint *param_3)
{
uint uVar1;
undefined4 *puVar2;
int iVar3;
uint *puVar4;
puVar4 = param_3;
if (3 < *param_3) {
puVar4 = *(uint **)*param_2;
*param_2 = (undefined4 *)*param_2 + 1;
*param_3 = *param_3 - 4;
}
*param_1 = puVar4;
puVar2 = (undefined4 *)FUN_005df0f5(0x30);
if (puVar2 == (undefined4 *)0x0) {
puVar2 = (undefined4 *)0x0;
}
else {
*puVar2 = DAT_00842770;
puVar2[1] = 0;
puVar2[2] = 0;
puVar2[3] = 0;
puVar2[4] = 0;
puVar2[5] = 0;
puVar2[6] = 0;
puVar2[7] = 0;
puVar2[8] = 0;
puVar2[9] = 0;
puVar2[10] = 0;
puVar2[0xb] = DAT_00842770;
}
FUN_005045a0(param_2,param_3);
uVar1 = param_1[2];
if (uVar1 <= (uint)param_1[3]) {
if (uVar1 == 0) {
iVar3 = 8;
}
else {
iVar3 = uVar1 * 2;
}
iVar3 = FUN_00500570(iVar3);
if (iVar3 == 0) {
return 1;
}
}
*(undefined4 **)(param_1[1] + param_1[3] * 4) = puVar2;
param_1[3] = param_1[3] + 1;
return 1;
}
// --- FUN_00504d80 at 0x00504D80 (size: 300) ---
void __fastcall FUN_00504d80(int param_1)
{
void *pvVar1;
uint uVar2;
uVar2 = 0;
if (*(int *)(param_1 + 0xc) != 0) {
do {
pvVar1 = *(void **)(*(int *)(param_1 + 4) + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
if (*(int **)((int)pvVar1 + 8) != (int *)0x0) {
(**(code **)(**(int **)((int)pvVar1 + 8) + 0x14))();
*(undefined4 *)((int)pvVar1 + 8) = 0;
}
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0xc));
}
*(undefined4 *)(param_1 + 0xc) = 0;
*(undefined4 *)(param_1 + 8) = 0;
operator_delete__(*(void **)(param_1 + 4));
*(undefined4 *)(param_1 + 4) = 0;
uVar2 = 0;
if (*(int *)(param_1 + 0x18) != 0) {
do {
pvVar1 = *(void **)(*(int *)(param_1 + 0x10) + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
if (*(int **)((int)pvVar1 + 8) != (int *)0x0) {
(**(code **)(**(int **)((int)pvVar1 + 8) + 0x14))();
*(undefined4 *)((int)pvVar1 + 8) = 0;
}
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x18));
}
*(undefined4 *)(param_1 + 0x18) = 0;
*(undefined4 *)(param_1 + 0x14) = 0;
operator_delete__(*(void **)(param_1 + 0x10));
*(undefined4 *)(param_1 + 0x10) = 0;
uVar2 = 0;
if (*(int *)(param_1 + 0x24) != 0) {
do {
pvVar1 = *(void **)(*(int *)(param_1 + 0x1c) + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
if (*(int **)((int)pvVar1 + 8) != (int *)0x0) {
(**(code **)(**(int **)((int)pvVar1 + 8) + 0x14))();
*(undefined4 *)((int)pvVar1 + 8) = 0;
}
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x24));
}
*(undefined4 *)(param_1 + 0x24) = 0;
*(undefined4 *)(param_1 + 0x20) = 0;
operator_delete__(*(void **)(param_1 + 0x1c));
*(undefined4 *)(param_1 + 0x1c) = 0;
uVar2 = 0;
if (*(int *)(param_1 + 0x30) != 0) {
do {
pvVar1 = *(void **)(*(int *)(param_1 + 0x28) + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
FUN_005046b0();
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x30));
}
*(undefined4 *)(param_1 + 0x30) = 0;
*(undefined4 *)(param_1 + 0x2c) = 0;
operator_delete__(*(void **)(param_1 + 0x28));
*(undefined4 *)(param_1 + 0x28) = 0;
return;
}
// --- FUN_00504eb0 at 0x00504EB0 (size: 346) ---
undefined4 __thiscall FUN_00504eb0(int *param_1,undefined4 param_2,undefined4 param_3)
{
undefined4 uVar1;
int iVar2;
int iVar3;
int iVar4;
uint uVar5;
int local_2c;
int local_28;
int local_24 [6];
undefined4 auStack_c [3];
iVar2 = FUN_00504820(param_2,local_24 + 5,local_24 + 2);
if (iVar2 == 0) {
return 0;
}
if ((DAT_0084271c != 0) ||
(DAT_0084271c = thunk_FUN_005df0f5(*param_1 * *param_1 * 4), DAT_0084271c != 0)) {
iVar2 = DAT_0084271c;
iVar3 = FUN_005043a0(0x20);
local_28 = iVar3;
FUN_00503e50(param_2,&local_2c,local_24);
iVar4 = local_2c;
uVar1 = param_3;
if ((local_2c != 0) && (iVar3 != 0)) {
local_24[5] = iVar3;
}
iVar2 = FUN_00503fe0(iVar2,param_3,local_24[5]);
if (iVar2 != 0) {
if (iVar4 == 0) {
uVar5 = 0;
do {
iVar2 = *(int *)((int)local_24 + uVar5 + 8);
if (iVar2 == 0) break;
iVar2 = FUN_00504160(iVar2,&local_2c,&param_3,param_2);
if (iVar2 == 0) {
return 0;
}
FUN_00504320(DAT_0084271c,uVar1,*(undefined4 *)(local_2c + 8),param_3,
*(undefined4 *)((int)auStack_c + uVar5));
uVar5 = uVar5 + 4;
} while (uVar5 < 0xc);
iVar2 = local_28;
if (local_28 != 0) {
uVar5 = 0;
do {
if (local_24[uVar5] == 0) {
return 1;
}
iVar4 = FUN_00504060(local_24[uVar5],&local_28,&param_3,param_2);
if (iVar4 != 0) {
FUN_00504320(DAT_0084271c,uVar1,*(undefined4 *)(local_28 + 8),param_3,iVar2);
}
uVar5 = uVar5 + 1;
} while (uVar5 < 2);
}
}
return 1;
}
}
return 0;
}
// --- FUN_00505010 at 0x00505010 (size: 791) ---
undefined4 __thiscall FUN_00505010(undefined4 *param_1,uint *param_2,uint *param_3)
{
uint uVar1;
uint *puVar2;
undefined4 uVar3;
int *piVar4;
uint *puVar5;
undefined4 *puVar6;
int iVar7;
undefined4 *puVar8;
puVar5 = param_3;
piVar4 = (int *)param_2;
if (3 < *param_3) {
*param_1 = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *param_3;
*param_3 = uVar1 - 4;
if (3 < uVar1 - 4) {
puVar2 = *(uint **)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*param_3 = *param_3 - 4;
param_3 = puVar2;
}
}
FUN_00500570(param_3);
for (puVar2 = param_3; puVar2 != (uint *)0x0; puVar2 = (uint *)((int)puVar2 + -1)) {
puVar6 = (undefined4 *)FUN_005df0f5(0xc);
puVar8 = (undefined4 *)0x0;
if (puVar6 != (undefined4 *)0x0) {
*puVar6 = 0;
uVar3 = DAT_00842770;
puVar6[2] = 0;
puVar6[1] = uVar3;
puVar8 = puVar6;
}
if (3 < *puVar5) {
*puVar8 = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *puVar5;
*puVar5 = uVar1 - 4;
if (3 < uVar1 - 4) {
uVar3 = *(undefined4 *)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*puVar5 = *puVar5 - 4;
puVar8[1] = uVar3;
}
}
uVar1 = param_1[2];
if ((uint)param_1[3] < uVar1) {
LAB_005050dc:
*(undefined4 **)(param_1[1] + param_1[3] * 4) = puVar8;
param_1[3] = param_1[3] + 1;
}
else {
if (uVar1 == 0) {
iVar7 = 8;
}
else {
iVar7 = uVar1 * 2;
}
iVar7 = FUN_00500570(iVar7);
if (iVar7 != 0) goto LAB_005050dc;
}
}
if (3 < *puVar5) {
param_3 = *(uint **)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*puVar5 = *puVar5 - 4;
}
FUN_00500570(param_3);
for (puVar2 = param_3; puVar2 != (uint *)0x0; puVar2 = (uint *)((int)puVar2 + -1)) {
puVar6 = (undefined4 *)FUN_005df0f5(0xc);
puVar8 = (undefined4 *)0x0;
if (puVar6 != (undefined4 *)0x0) {
*puVar6 = 0;
uVar3 = DAT_00842770;
puVar6[2] = 0;
puVar6[1] = uVar3;
puVar8 = puVar6;
}
if (3 < *puVar5) {
*puVar8 = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *puVar5;
*puVar5 = uVar1 - 4;
if (3 < uVar1 - 4) {
uVar3 = *(undefined4 *)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*puVar5 = *puVar5 - 4;
puVar8[1] = uVar3;
}
}
uVar1 = param_1[5];
if ((uint)param_1[6] < uVar1) {
LAB_00505194:
*(undefined4 **)(param_1[4] + param_1[6] * 4) = puVar8;
param_1[6] = param_1[6] + 1;
}
else {
if (uVar1 == 0) {
iVar7 = 8;
}
else {
iVar7 = uVar1 * 2;
}
iVar7 = FUN_00500570(iVar7);
if (iVar7 != 0) goto LAB_00505194;
}
}
if (3 < *puVar5) {
param_3 = *(uint **)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*puVar5 = *puVar5 - 4;
}
FUN_00500570(param_3);
for (puVar2 = param_3; puVar2 != (uint *)0x0; puVar2 = (uint *)((int)puVar2 + -1)) {
puVar6 = (undefined4 *)FUN_005df0f5(0xc);
puVar8 = (undefined4 *)0x0;
if (puVar6 != (undefined4 *)0x0) {
*puVar6 = 0;
uVar3 = DAT_00842770;
puVar6[2] = 0;
puVar6[1] = uVar3;
puVar8 = puVar6;
}
if (3 < *puVar5) {
*puVar8 = *(undefined4 *)*param_2;
*param_2 = *param_2 + 4;
uVar1 = *puVar5;
*puVar5 = uVar1 - 4;
if (3 < uVar1 - 4) {
uVar3 = *(undefined4 *)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*puVar5 = *puVar5 - 4;
puVar8[1] = uVar3;
}
}
uVar1 = param_1[8];
if ((uint)param_1[9] < uVar1) {
LAB_0050524c:
*(undefined4 **)(param_1[7] + param_1[9] * 4) = puVar8;
param_1[9] = param_1[9] + 1;
}
else {
if (uVar1 == 0) {
iVar7 = 8;
}
else {
iVar7 = uVar1 * 2;
}
iVar7 = FUN_00500570(iVar7);
if (iVar7 != 0) goto LAB_0050524c;
}
}
if (3 < *puVar5) {
param_3 = *(uint **)*param_2;
*param_2 = (uint)((undefined4 *)*param_2 + 1);
*puVar5 = *puVar5 - 4;
}
FUN_00500570(param_3);
param_2 = (uint *)0x0;
if (param_3 == (uint *)0x0) {
return 1;
}
do {
puVar6 = (undefined4 *)FUN_005df0f5(0x10);
puVar8 = (undefined4 *)0x0;
if (puVar6 != (undefined4 *)0x0) {
*puVar6 = 0x1f;
puVar6[1] = 0;
puVar6[2] = 0;
puVar6[3] = 0;
puVar8 = puVar6;
}
iVar7 = FUN_00504cc0(piVar4,puVar5);
if (iVar7 == 0) {
return 0;
}
uVar1 = param_1[0xb];
if ((uint)param_1[0xc] < uVar1) {
LAB_005052f4:
*(undefined4 **)(param_1[10] + param_1[0xc] * 4) = puVar8;
param_1[0xc] = param_1[0xc] + 1;
}
else {
if (uVar1 == 0) {
iVar7 = 8;
}
else {
iVar7 = uVar1 * 2;
}
iVar7 = FUN_00500570(iVar7);
if (iVar7 != 0) goto LAB_005052f4;
}
param_2 = (uint *)((int)param_2 + 1);
if (param_3 <= param_2) {
return 1;
}
} while( true );
}
// --- FUN_00505330 at 0x00505330 (size: 49) ---
void __fastcall FUN_00505330(int param_1)
{
FUN_00504d80();
operator_delete__(*(void **)(param_1 + 0x28));
operator_delete__(*(void **)(param_1 + 0x1c));
operator_delete__(*(void **)(param_1 + 0x10));
operator_delete__(*(void **)(param_1 + 4));
return;
}
// --- FUN_00505370 at 0x00505370 (size: 149) ---
undefined4 FUN_00505370(int param_1)
{
uint uVar1;
int iVar2;
uint uVar3;
int *piVar4;
iVar2 = FUN_006b5980();
uVar1 = *(uint *)(param_1 + 0x28);
uVar3 = (**(uint **)(iVar2 + 4) >>
((byte)*(undefined4 *)(&DAT_007c712c + DAT_00846774 * 4) & 0x1f)) / (uVar1 >> 0x1c);
if (uVar3 < DAT_0081f928) {
uVar3 = DAT_0081f928;
}
FUN_00536c20();
iVar2 = FUN_00504eb0(uVar1,uVar3);
if (iVar2 != 0) {
piVar4 = (int *)FUN_005411d0(DAT_0084271c,uVar3,uVar3);
if (piVar4 != (int *)0x0) {
iVar2 = FUN_00537090(piVar4,3);
if (iVar2 != 0) {
(**(code **)(*piVar4 + 0x14))();
return 1;
}
(**(code **)(*piVar4 + 0x14))();
}
}
return 0;
}
// --- FUN_00505410 at 0x00505410 (size: 132) ---
int * __thiscall FUN_00505410(uint *param_1,undefined4 param_2,uint param_3)
{
int *piVar1;
int iVar2;
int *piVar3;
param_3 = (*param_1 >> ((byte)*(undefined4 *)(&DAT_007c712c + DAT_00846774 * 4) & 0x1f)) / param_3
;
if (param_3 < DAT_0081f928) {
param_3 = DAT_0081f928;
}
piVar1 = (int *)FUN_00536fb0(3);
if (piVar1 != (int *)0x0) {
(**(code **)(*piVar1 + 0x44))(param_2);
iVar2 = FUN_00504eb0(param_2,param_3);
if (iVar2 != 0) {
piVar3 = (int *)FUN_005411d0(DAT_0084271c,param_3,param_3);
if (piVar3 != (int *)0x0) {
FUN_00537090(piVar3,3);
(**(code **)(*piVar3 + 0x14))();
}
}
}
return piVar1;
}
// --- FUN_005054a0 at 0x005054A0 (size: 17) ---
void __fastcall FUN_005054a0(int param_1)
{
FUN_005aac70(param_1 + 4,param_1 + 0x3c);
return;
}
// --- FUN_005054c0 at 0x005054C0 (size: 117) ---
undefined4 FUN_005054c0(uint param_1,uint param_2,int *param_3,int *param_4)
{
uint uVar1;
int iVar2;
int iVar3;
if (param_1 == 0) {
return 0;
}
if (param_2 == 0) {
uVar1 = 0;
iVar3 = 0;
}
else {
uVar1 = param_2 >> 0x15 & 0x7f8;
iVar3 = (param_2 >> 0x10 & 0xff) << 3;
}
iVar2 = uVar1 - (param_1 >> 0x15 & 0x7f8);
*param_3 = (int)(iVar2 + (iVar2 >> 0x1f & 7U)) >> 3;
iVar3 = iVar3 + (param_1 >> 0x10 & 0xff) * -8;
*param_4 = (int)(iVar3 + (iVar3 >> 0x1f & 7U)) >> 3;
return 1;
}
// --- FUN_00505540 at 0x00505540 (size: 121) ---
void __fastcall FUN_00505540(int param_1)
{
FUN_0054c3d0(0);
if (*(int *)(param_1 + 0x24) != 0) {
FUN_00536c10(*(int *)(param_1 + 0x24));
*(undefined4 *)(param_1 + 0x24) = 0;
}
FUN_0054c3f0(0);
if (*(int *)(param_1 + 0x28) != 0) {
FUN_00536c10(*(int *)(param_1 + 0x28));
*(undefined4 *)(param_1 + 0x28) = 0;
}
FUN_0054c3e0(0);
if (*(int *)(param_1 + 0x2c) != 0) {
FUN_00536c10(*(int *)(param_1 + 0x2c));
*(undefined4 *)(param_1 + 0x2c) = 0;
}
FUN_0054c400(0);
if (*(int *)(param_1 + 0x30) != 0) {
FUN_00536c10(*(int *)(param_1 + 0x30));
*(undefined4 *)(param_1 + 0x30) = 0;
}
return;
}
// --- FUN_005055c0 at 0x005055C0 (size: 147) ---
void __fastcall FUN_005055c0(int param_1)
{
int iVar1;
int iVar2;
if ((*(int *)(param_1 + 8) != 0) && (iVar1 = 0, 0 < *(int *)(param_1 + 4))) {
do {
iVar2 = 0;
if (0 < *(int *)(param_1 + 4)) {
do {
if (*(int *)(*(int *)(param_1 + 8) + (*(int *)(param_1 + 4) * iVar1 + iVar2) * 4) != 0) {
FUN_00530a30();
*(undefined4 *)(*(int *)(param_1 + 8) + (*(int *)(param_1 + 4) * iVar1 + iVar2) * 4) = 0
;
}
iVar2 = iVar2 + 1;
} while (iVar2 < *(int *)(param_1 + 4));
}
iVar1 = iVar1 + 1;
} while (iVar1 < *(int *)(param_1 + 4));
}
if (*(void **)(param_1 + 8) != (void *)0x0) {
operator_delete__(*(void **)(param_1 + 8));
*(undefined4 *)(param_1 + 8) = 0;
}
if (*(void **)(param_1 + 0xc) != (void *)0x0) {
operator_delete__(*(void **)(param_1 + 0xc));
*(undefined4 *)(param_1 + 0xc) = 0;
}
if (*(int *)(param_1 + 0x20) != 0) {
FUN_005081c0();
}
*(undefined4 *)(param_1 + 0x10) = 0;
*(undefined4 *)(param_1 + 0x14) = 0;
return;
}
// --- FUN_00505660 at 0x00505660 (size: 38) ---
undefined4 __thiscall FUN_00505660(int *param_1,int param_2)
{
if ((0 < param_2) && (param_1[2] == 0)) {
*param_1 = param_2;
param_1[1] = param_2 * 2 + 1;
return 1;
}
return 0;
}
// --- FUN_00505690 at 0x00505690 (size: 22) ---
void __fastcall FUN_00505690(int param_1)
{
if ((*(int *)(param_1 + 0x10) != 0) && (*(int *)(param_1 + 0x20) != 0)) {
FUN_00507830();
return;
}
return;
}
// --- FUN_005056b0 at 0x005056B0 (size: 602) ---
void __fastcall FUN_005056b0(int param_1)
{
int iVar1;
undefined4 uVar2;
int iVar3;
int iVar4;
int iVar5;
int iVar6;
int iVar7;
int iVar8;
int local_8;
if (*(int *)(param_1 + 0xc) == 0) {
uVar2 = thunk_FUN_005df0f5(*(int *)(param_1 + 4) * *(int *)(param_1 + 4) * 4);
*(undefined4 *)(param_1 + 0xc) = uVar2;
}
**(undefined4 **)(param_1 + 0xc) =
*(undefined4 *)
(*(int *)(param_1 + 8) +
(*(int *)(param_1 + 0x18) * *(int *)(param_1 + 4) + *(int *)(param_1 + 0x1c)) * 4);
iVar3 = *(int *)(param_1 + 0x1c);
iVar7 = *(int *)(param_1 + 0x18);
iVar8 = 1;
local_8 = 1;
if (iVar3 < iVar7) {
iVar3 = (*(int *)(param_1 + 4) - iVar3) + -1;
if (iVar7 <= iVar3) goto LAB_00505718;
}
else {
iVar7 = (*(int *)(param_1 + 4) - iVar7) + -1;
if (iVar7 < iVar3) goto LAB_00505718;
}
iVar3 = iVar7;
LAB_00505718:
if (0 < iVar3) {
do {
iVar7 = 0;
if (0 < iVar8) {
do {
iVar4 = 0;
do {
iVar5 = *(int *)((int)&DAT_0081dd1c + iVar4) * iVar7 +
*(int *)((int)&DAT_0081dcfc + iVar4) * iVar8 +
*(int *)((int)&DAT_0081dcdc + iVar4) + *(int *)(param_1 + 0x18);
iVar6 = *(int *)((int)&DAT_0081dc9c + iVar4) * iVar7 +
*(int *)((int)&DAT_0081dcbc + iVar4) * iVar8 +
*(int *)((int)&DAT_0081dc7c + iVar4) + *(int *)(param_1 + 0x1c);
iVar1 = *(int *)(param_1 + 4);
if ((((iVar5 < iVar1) && (iVar6 < iVar1)) && (-1 < iVar5)) && (-1 < iVar6)) {
*(undefined4 *)(*(int *)(param_1 + 0xc) + local_8 * 4) =
*(undefined4 *)(*(int *)(param_1 + 8) + (iVar1 * iVar5 + iVar6) * 4);
local_8 = local_8 + 1;
}
iVar5 = *(int *)((int)&DAT_0081dd20 + iVar4) * iVar7 +
*(int *)((int)&DAT_0081dd00 + iVar4) * iVar8 +
*(int *)((int)&DAT_0081dce0 + iVar4) + *(int *)(param_1 + 0x18);
iVar6 = *(int *)((int)&DAT_0081dca0 + iVar4) * iVar7 +
*(int *)((int)&DAT_0081dcc0 + iVar4) * iVar8 +
*(int *)((int)&DAT_0081dc80 + iVar4) + *(int *)(param_1 + 0x1c);
iVar1 = *(int *)(param_1 + 4);
if (((iVar5 < iVar1) && (iVar6 < iVar1)) && ((-1 < iVar5 && (-1 < iVar6)))) {
*(undefined4 *)(*(int *)(param_1 + 0xc) + local_8 * 4) =
*(undefined4 *)(*(int *)(param_1 + 8) + (iVar1 * iVar5 + iVar6) * 4);
local_8 = local_8 + 1;
}
iVar5 = *(int *)((int)&DAT_0081dd24 + iVar4) * iVar7 +
*(int *)((int)&DAT_0081dd04 + iVar4) * iVar8 +
*(int *)((int)&DAT_0081dce4 + iVar4) + *(int *)(param_1 + 0x18);
iVar6 = *(int *)((int)&DAT_0081dca4 + iVar4) * iVar7 +
*(int *)((int)&DAT_0081dcc4 + iVar4) * iVar8 +
*(int *)((int)&DAT_0081dc84 + iVar4) + *(int *)(param_1 + 0x1c);
iVar1 = *(int *)(param_1 + 4);
if (((iVar5 < iVar1) && (iVar6 < iVar1)) && ((-1 < iVar5 && (-1 < iVar6)))) {
*(undefined4 *)(*(int *)(param_1 + 0xc) + local_8 * 4) =
*(undefined4 *)(*(int *)(param_1 + 8) + (iVar1 * iVar5 + iVar6) * 4);
local_8 = local_8 + 1;
}
iVar5 = *(int *)((int)&DAT_0081dd28 + iVar4) * iVar7 +
*(int *)((int)&DAT_0081dd08 + iVar4) * iVar8 +
*(int *)((int)&DAT_0081dce8 + iVar4) + *(int *)(param_1 + 0x18);
iVar6 = *(int *)((int)&DAT_0081dca8 + iVar4) * iVar7 +
*(int *)((int)&DAT_0081dcc8 + iVar4) * iVar8 +
*(int *)((int)&DAT_0081dc88 + iVar4) + *(int *)(param_1 + 0x1c);
iVar1 = *(int *)(param_1 + 4);
if ((((iVar5 < iVar1) && (iVar6 < iVar1)) && (-1 < iVar5)) && (-1 < iVar6)) {
*(undefined4 *)(*(int *)(param_1 + 0xc) + local_8 * 4) =
*(undefined4 *)(*(int *)(param_1 + 8) + (iVar1 * iVar5 + iVar6) * 4);
local_8 = local_8 + 1;
}
iVar4 = iVar4 + 0x10;
} while (iVar4 < 0x20);
iVar7 = iVar7 + 1;
} while (iVar7 < iVar8);
}
iVar8 = iVar8 + 1;
} while (iVar8 <= iVar3);
}
return;
}
// --- FUN_00505920 at 0x00505920 (size: 138) ---
void __fastcall FUN_00505920(int param_1)
{
uint uVar1;
uint uVar2;
uint uVar3;
uVar1 = *(uint *)(param_1 + 4);
uVar3 = 0;
if (uVar1 != 0) {
do {
uVar2 = 0;
if (uVar1 != 0) {
do {
if (*(int *)(*(int *)(param_1 + 8) + (uVar1 * uVar3 + uVar2) * 4) != 0) {
FUN_00530ac0();
FUN_005301a0();
}
uVar1 = *(uint *)(param_1 + 4);
uVar2 = uVar2 + 1;
} while (uVar2 < uVar1);
}
uVar1 = *(uint *)(param_1 + 4);
uVar3 = uVar3 + 1;
} while (uVar3 < uVar1);
}
uVar1 = *(uint *)(param_1 + 4);
uVar3 = 0;
if (uVar1 != 0) {
do {
uVar2 = 0;
if (uVar1 != 0) {
do {
if (*(int *)(*(int *)(param_1 + 8) + (uVar1 * uVar3 + uVar2) * 4) != 0) {
FUN_00531780(0);
FUN_005300f0();
}
uVar1 = *(uint *)(param_1 + 4);
uVar2 = uVar2 + 1;
} while (uVar2 < uVar1);
}
uVar1 = *(uint *)(param_1 + 4);
uVar3 = uVar3 + 1;
} while (uVar3 < uVar1);
}
return;
}
// --- FUN_005059f0 at 0x005059F0 (size: 267) ---
void __thiscall FUN_005059f0(int *param_1,int param_2,int param_3,undefined4 *param_4,uint *param_5)
{
int iVar1;
uint uVar2;
int iVar3;
uint uVar4;
uint uVar5;
uint uVar6;
uVar5 = param_3 - *param_1;
uVar6 = param_2 - *param_1;
iVar3 = (uVar5 ^ (int)uVar5 >> 0x1f) - ((int)uVar5 >> 0x1f);
iVar1 = (uVar6 ^ (int)uVar6 >> 0x1f) - ((int)uVar6 >> 0x1f);
if (iVar1 <= iVar3) {
iVar1 = iVar3;
}
if (iVar1 < 2) {
*param_4 = 1;
uVar2 = 1;
}
else if (iVar1 < 3) {
*param_4 = 2;
uVar2 = 2;
}
else {
if (4 < iVar1) {
*param_4 = 8;
*param_5 = 0;
return;
}
*param_4 = 4;
uVar2 = 4;
}
if (uVar6 == uVar2) {
if (uVar5 == uVar2) {
*param_5 = 7;
return;
}
*param_5 = ((uVar5 != -uVar2) - 1 & 5) + 3;
return;
}
uVar4 = -uVar2;
if (uVar6 != uVar4) {
if (uVar5 == uVar2) {
*param_5 = 1;
return;
}
*param_5 = (uVar5 != uVar4) - 1 & 2;
return;
}
if (uVar5 == uVar2) {
*param_5 = 5;
return;
}
*param_5 = (uint)(uVar5 == uVar4) * 2 + 4;
return;
}
// --- FUN_00505b00 at 0x00505B00 (size: 166) ---
/* WARNING: Function: __chkstk replaced with injection: alloca_probe */
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void FUN_00505b00(int param_1)
{
float fVar1;
float fVar2;
int *piVar3;
int iVar4;
int iVar5;
int iVar6;
undefined1 *puVar7;
uint uVar8;
int iVar9;
undefined1 auStack_92c [128];
undefined1 auStack_8ac [2172];
undefined4 uStack_30;
iVar4 = param_1;
iVar5 = *(int *)(param_1 + 0x48);
if (iVar5 == 8) {
if (*(int *)(param_1 + 0xfc) == 2) {
iVar5 = 0;
if (0 < *(int *)(param_1 + 0x48) * *(int *)(param_1 + 0x48)) {
iVar4 = 0;
do {
*(undefined4 *)(*(int *)(param_1 + 0x90) + 0x104 + iVar4) = 2;
iVar5 = iVar5 + 1;
iVar4 = iVar4 + 0x108;
} while (iVar5 < *(int *)(param_1 + 0x48) * *(int *)(param_1 + 0x48));
return;
}
}
else {
uStack_30 = 0x505bb6;
puVar7 = auStack_92c;
fVar1 = *(float *)(param_1 + 0xd4);
fVar2 = *(float *)(param_1 + 0xd8);
param_1 = 0;
do {
FUN_0054dc00(fVar1,(float)param_1 * _DAT_007c7178 + fVar2,puVar7);
param_1 = param_1 + 1;
puVar7 = puVar7 + 0x80;
} while (param_1 < *(int *)(iVar4 + 0x48) + 1);
iVar5 = *(int *)(iVar4 + 0x48);
uVar8 = 0;
if (0 < iVar5) {
do {
iVar5 = iVar5 + 1;
param_1 = 0;
if (0 < iVar5) {
do {
FUN_0054dc00((float)(int)(uVar8 + 1) * _DAT_007c7178 + fVar1,
(float)param_1 * _DAT_007c7178 + fVar2,
auStack_92c + ((uVar8 - 1 & 1) * iVar5 + param_1) * 0x80);
param_1 = param_1 + 1;
iVar5 = *(int *)(iVar4 + 0x48) + 1;
} while (param_1 < iVar5);
}
iVar5 = *(int *)(iVar4 + 0x48);
iVar9 = 0;
if (0 < iVar5) {
do {
piVar3 = (int *)((iVar5 * uVar8 + iVar9) * 0x108 + *(int *)(iVar4 + 0x90));
if ((piVar3 != (int *)0x0) && (iVar5 = (**(code **)(*piVar3 + 0x68))(), iVar5 == 0)) {
iVar5 = *(int *)(iVar4 + 0x48) + 1;
iVar6 = ((uVar8 - 1 & 1) * iVar5 + iVar9) * 0x80;
iVar5 = ((uVar8 & 1) * iVar5 + iVar9) * 0x80;
iVar5 = FUN_0054e860(auStack_92c + iVar5,auStack_8ac + iVar5,auStack_92c + iVar6,
auStack_8ac + iVar6,*(undefined4 *)(iVar4 + 0xe0),
*(undefined4 *)(iVar4 + 0xe4));
piVar3[0x41] = iVar5;
}
iVar5 = *(int *)(iVar4 + 0x48);
iVar9 = iVar9 + 1;
} while (iVar9 < iVar5);
}
iVar5 = *(int *)(iVar4 + 0x48);
uVar8 = uVar8 + 1;
} while ((int)uVar8 < iVar5);
}
}
}
else {
iVar4 = 0;
if (0 < iVar5 * iVar5) {
iVar5 = 0;
do {
*(undefined4 *)(*(int *)(param_1 + 0x90) + 0x104 + iVar5) = 1;
iVar4 = iVar4 + 1;
iVar5 = iVar5 + 0x108;
} while (iVar4 < *(int *)(param_1 + 0x48) * *(int *)(param_1 + 0x48));
return;
}
}
return;
}
// --- FUN_00505bac at 0x00505BAC (size: 392) ---
/* WARNING: Function: __chkstk replaced with injection: alloca_probe */
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void FUN_00505bac(void)
{
undefined4 uVar1;
int *piVar2;
undefined4 uVar3;
uint uVar4;
int iVar5;
undefined1 *puVar6;
uint uVar7;
int unaff_EBP;
int unaff_ESI;
int iVar8;
int iVar9;
undefined1 auStack_900 [2300];
undefined4 uStack_4;
uStack_4 = 0x505bb6;
puVar6 = auStack_900;
uVar3 = *(undefined4 *)(unaff_ESI + 0xd4);
uVar1 = *(undefined4 *)(unaff_ESI + 0xd8);
iVar8 = 0;
*(undefined1 **)(unaff_EBP + -4) = auStack_900;
*(undefined4 *)(unaff_EBP + -0xc) = uVar3;
*(undefined4 *)(unaff_EBP + -8) = uVar1;
*(undefined4 *)(unaff_EBP + 8) = 0;
do {
FUN_0054dc00(*(undefined4 *)(unaff_EBP + -0xc),
(float)*(int *)(unaff_EBP + 8) * _DAT_007c7178 + *(float *)(unaff_EBP + -8),puVar6)
;
iVar9 = *(int *)(unaff_ESI + 0x48);
iVar8 = iVar8 + 1;
puVar6 = puVar6 + 0x80;
*(int *)(unaff_EBP + 8) = iVar8;
} while (iVar8 < iVar9 + 1);
iVar8 = *(int *)(unaff_ESI + 0x48);
uVar7 = 0;
if (0 < iVar8) {
do {
iVar9 = 0;
iVar8 = iVar8 + 1;
*(undefined4 *)(unaff_EBP + 8) = 0;
if (0 < iVar8) {
uVar4 = uVar7 - 1 & 1;
*(uint *)(unaff_EBP + -0x10) = uVar7 + 1;
*(uint *)(unaff_EBP + -0x14) = uVar4;
*(float *)(unaff_EBP + -0x10) = (float)*(int *)(unaff_EBP + -0x10);
while( true ) {
FUN_0054dc00(*(float *)(unaff_EBP + -0x10) * _DAT_007c7178 + *(float *)(unaff_EBP + -0xc),
(float)*(int *)(unaff_EBP + 8) * _DAT_007c7178 + *(float *)(unaff_EBP + -8),
(uVar4 * iVar8 + iVar9) * 0x80 + *(int *)(unaff_EBP + -4));
iVar9 = iVar9 + 1;
iVar8 = *(int *)(unaff_ESI + 0x48) + 1;
*(int *)(unaff_EBP + 8) = iVar9;
if (iVar8 <= iVar9) break;
uVar4 = *(uint *)(unaff_EBP + -0x14);
}
}
iVar8 = *(int *)(unaff_ESI + 0x48);
iVar9 = 0;
if (0 < iVar8) {
do {
piVar2 = (int *)((iVar8 * uVar7 + iVar9) * 0x108 + *(int *)(unaff_ESI + 0x90));
*(int **)(unaff_EBP + 8) = piVar2;
if ((piVar2 != (int *)0x0) && (iVar8 = (**(code **)(*piVar2 + 0x68))(), iVar8 == 0)) {
uVar3 = *(undefined4 *)(unaff_ESI + 0xe0);
*(undefined4 *)(unaff_EBP + -0x18) = *(undefined4 *)(unaff_ESI + 0xe4);
iVar8 = *(int *)(unaff_ESI + 0x48) + 1;
*(undefined4 *)(unaff_EBP + -0x1c) = uVar3;
iVar5 = *(int *)(unaff_EBP + -4) + ((uVar7 - 1 & 1) * iVar8 + iVar9) * 0x80;
iVar8 = *(int *)(unaff_EBP + -4) + ((uVar7 & 1) * iVar8 + iVar9) * 0x80;
uVar3 = FUN_0054e860(iVar8,iVar8 + 0x80,iVar5,iVar5 + 0x80,
*(undefined4 *)(unaff_EBP + -0x1c),
*(undefined4 *)(unaff_EBP + -0x18));
*(undefined4 *)(*(int *)(unaff_EBP + 8) + 0x104) = uVar3;
}
iVar8 = *(int *)(unaff_ESI + 0x48);
iVar9 = iVar9 + 1;
} while (iVar9 < iVar8);
}
iVar8 = *(int *)(unaff_ESI + 0x48);
uVar7 = uVar7 + 1;
} while ((int)uVar7 < iVar8);
}
return;
}
// --- FUN_00505d40 at 0x00505D40 (size: 55) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void FUN_00505d40(int param_1)
{
DAT_008427a8 = param_1 != 0;
_DAT_00842798 = 0;
_DAT_0084279c = 0;
_DAT_008427a0 = 0;
_DAT_008427a4 = 0;
return;
}
// --- FUN_00505d80 at 0x00505D80 (size: 68) ---
uint * FUN_00505d80(uint *param_1,uint param_2,int param_3)
{
if ((((-1 < (int)param_2) && (-1 < param_3)) && ((int)param_2 < 0x7f8)) && (param_3 < 0x7f8)) {
*param_1 = ((param_2 & 0xfffffff8) << 5 | param_3 >> 3) << 0x10 | 0xffff;
return param_1;
}
*param_1 = 0;
return param_1;
}
// --- FUN_00505dd0 at 0x00505DD0 (size: 157) ---
undefined4 * __fastcall FUN_00505dd0(undefined4 *param_1)
{
int iVar1;
undefined4 uVar2;
param_1[2] = 0;
param_1[3] = 0;
param_1[4] = 0;
param_1[5] = 0;
param_1[6] = 0;
param_1[7] = 0;
param_1[9] = 0;
param_1[10] = 0;
param_1[0xb] = 0;
param_1[0xc] = 0;
*param_1 = 5;
param_1[1] = 0xb;
DAT_00842780 = 0x3ecccccd;
DAT_00842950 = 0x3f99999a;
DAT_00842954 = 0;
DAT_00842958 = 0x3f000000;
FUN_00530850();
iVar1 = FUN_005df0f5(0x2c);
if (iVar1 != 0) {
uVar2 = FUN_00507c50();
param_1[8] = uVar2;
return param_1;
}
param_1[8] = 0;
return param_1;
}
// --- FUN_00505e70 at 0x00505E70 (size: 76) ---
void __fastcall FUN_00505e70(int param_1)
{
void *pvVar1;
FUN_005055c0();
if (DAT_00842790 != (void *)0x0) {
operator_delete__(DAT_00842790);
DAT_00842790 = (void *)0x0;
}
pvVar1 = *(void **)(param_1 + 0x20);
if (pvVar1 != (void *)0x0) {
FUN_00507d40();
operator_delete(pvVar1);
*(undefined4 *)(param_1 + 0x20) = 0;
}
FUN_00505540();
return;
}
// --- FUN_00505ec0 at 0x00505EC0 (size: 100) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_00505ec0(int param_1,int param_2,int param_3,int param_4)
{
int iVar1;
iVar1 = *(int *)(param_1 + 0x1c);
*(float *)(param_2 + 0xd4) = (float)(param_3 - *(int *)(param_1 + 0x18)) * _DAT_00842824;
*(float *)(param_2 + 0xd8) = (float)(param_4 - iVar1) * _DAT_00842824;
*(undefined4 *)(param_2 + 0xdc) = 0;
return;
}
// --- FUN_00505f30 at 0x00505F30 (size: 392) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall
FUN_00505f30(int param_1,float param_2,undefined4 param_3,float *param_4,undefined4 param_5)
{
float fVar1;
float fVar2;
float fVar3;
int iVar4;
int iVar5;
int iVar6;
DAT_00842780 = param_2;
DAT_0084277c = param_3;
if (DAT_008427a8 == '\0') {
DAT_00842950 = *param_4;
DAT_00842954 = param_4[1];
DAT_00842958 = param_4[2];
DAT_00842778 = param_5;
}
else {
iVar4 = FUN_004ff440(0x3f000000,&DAT_00842780,&DAT_0084277c,&DAT_00842950,&DAT_00842778);
if ((iVar4 != 0) && (DAT_00842780 < DAT_0084295c)) {
DAT_00842780 = DAT_0084295c;
}
}
fVar3 = DAT_00842958;
fVar2 = DAT_00842954;
fVar1 = DAT_00842950;
_DAT_008682c8 = DAT_00842950;
_DAT_008682d0 = DAT_00842958;
_DAT_008682cc = DAT_00842954;
FUN_00451a60(DAT_00842778);
_DAT_008682c0 = fVar2;
_DAT_008682bc = fVar1;
_DAT_008682c4 = fVar3;
DAT_008682d4 = 0;
if (DAT_0083da58 != 0) {
FUN_004530e0(SQRT(DAT_00842950 * DAT_00842950 +
DAT_00842954 * DAT_00842954 + DAT_00842958 * DAT_00842958) * _DAT_0079a1e8 +
DAT_00842780,DAT_0084277c);
}
if (*(int *)(param_1 + 8) != 0) {
iVar4 = *(int *)(param_1 + 4);
iVar5 = 0;
if (0 < iVar4) {
do {
iVar6 = 0;
if (0 < iVar4) {
do {
if (*(int *)(*(int *)(param_1 + 8) + (iVar4 * iVar5 + iVar6) * 4) != 0) {
FUN_00532440();
}
iVar4 = *(int *)(param_1 + 4);
iVar6 = iVar6 + 1;
} while (iVar6 < iVar4);
}
iVar4 = *(int *)(param_1 + 4);
iVar5 = iVar5 + 1;
} while (iVar5 < iVar4);
}
}
return;
}
// --- FUN_005060c0 at 0x005060C0 (size: 422) ---
undefined4 __thiscall FUN_005060c0(int *param_1,uint param_2,int *param_3)
{
uint uVar1;
undefined4 uVar2;
int iVar3;
int *piVar4;
int *piVar5;
int iVar6;
int iVar7;
undefined4 local_3c;
int local_30;
int local_28;
local_3c = 1;
piVar5 = param_1;
if (param_2 != 0) {
local_28 = (param_2 >> 0x10 & 0xff) << 3;
piVar5 = (int *)(param_2 >> 0x15 & 0x7f8);
}
*param_3 = 0;
iVar7 = *param_1;
iVar6 = -iVar7;
if (-iVar7 != iVar7 && iVar7 <= iVar6) {
return 1;
}
piVar5 = piVar5 + iVar7 * -2;
do {
local_30 = -iVar7;
if (-iVar7 == iVar7 || local_30 < iVar7) {
iVar7 = local_28 + iVar7 * -8;
do {
if (((((int)piVar5 < 0) || (iVar7 < 0)) || (0x7f7 < (int)piVar5)) || (0x7f7 < iVar7)) {
uVar1 = 0;
}
else {
uVar1 = (((uint)piVar5 & 0xfffffff8) << 5 | iVar7 >> 3) << 0x10 | 0xffff;
}
if (uVar1 != DAT_0084282c) {
uVar2 = FUN_004220b0(uVar1,1);
iVar3 = thunk_FUN_00413a30(uVar2);
if ((iVar3 == 2) || (iVar3 == 1)) {
uVar2 = FUN_004220b0(uVar1,1);
piVar4 = (int *)FUN_00415430(uVar2);
if (piVar4 == (int *)0x0) {
uVar2 = FUN_004220b0(uVar1 & 0xfffffffe | 0xfffe,2);
thunk_FUN_00413a30(uVar2);
goto LAB_00506210;
}
iVar3 = FUN_00530f80();
if (iVar3 == 0) {
local_3c = 0;
}
(**(code **)(*piVar4 + 0x14))();
}
else {
local_3c = 0;
if (iVar3 == -1) {
LAB_00506210:
local_3c = 0;
*param_3 = *param_3 + 1;
}
}
}
local_30 = local_30 + 1;
iVar7 = iVar7 + 8;
} while (local_30 <= *param_1);
}
iVar7 = *param_1;
iVar6 = iVar6 + 1;
piVar5 = piVar5 + 2;
if (iVar7 < iVar6) {
return local_3c;
}
} while( true );
}
// --- FUN_00506270 at 0x00506270 (size: 103) ---
void __thiscall FUN_00506270(int param_1,undefined4 param_2)
{
uint uVar1;
uint uVar2;
uint uVar3;
int local_8;
undefined1 local_4 [4];
uVar2 = *(uint *)(param_1 + 4);
uVar1 = 0;
if (uVar2 != 0) {
do {
uVar3 = 0;
if (uVar2 != 0) {
do {
FUN_005059f0(uVar1,uVar3,&local_8,local_4);
if ((local_8 == 1) && (*(int *)(*(int *)(param_1 + 8) + (uVar2 * uVar1 + uVar3) * 4) != 0)
) {
FUN_00531050(param_2);
}
uVar2 = *(uint *)(param_1 + 4);
uVar3 = uVar3 + 1;
} while (uVar3 < uVar2);
}
uVar2 = *(uint *)(param_1 + 4);
uVar1 = uVar1 + 1;
} while (uVar1 < uVar2);
}
return;
}
// --- FUN_005062e0 at 0x005062E0 (size: 1008) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __fastcall FUN_005062e0(int param_1)
{
float fVar1;
uint uVar2;
byte bVar3;
ushort uVar4;
undefined1 uVar5;
undefined1 uVar6;
int iVar7;
undefined4 local_28;
float local_24;
undefined4 local_20;
float local_1c;
int local_18;
double local_14;
undefined1 local_c [12];
if (*(int *)(param_1 + 0x10) != 0) {
if (*(int *)(param_1 + 0x20) != 0) {
FUN_00508010();
}
local_14 = _DAT_008379a8;
if ((_DAT_00842798 <= _DAT_008379a8) && (DAT_0084247c != 0)) {
_DAT_00842798 = *(double *)(*(int *)(DAT_0084247c + 0x50) + 8) + _DAT_008379a8;
if (DAT_008ee9c8 == 0) {
fVar1 = (float)_DAT_00795610;
}
else {
fVar1 = *(float *)(DAT_008ee9c8 + 0x48);
}
local_1c = fVar1;
if (_DAT_008427a0 < _DAT_008379a8) {
iVar7 = FUN_004ff440(fVar1,&local_24,&local_20,local_c,&local_18);
uVar2 = DAT_00842788;
if (iVar7 != 0) {
if (local_24 < DAT_0084295c) {
local_24 = DAT_0084295c;
}
if (DAT_008427a9 != '\0') {
if (_DAT_007938b0 <= _DAT_008427b8) {
local_24 = DAT_008427ac;
local_20 = DAT_00842788;
}
else {
uVar4 = local_20._2_2_;
local_1c = (float)((local_20._2_2_ & 0xff) - (DAT_00842788 >> 0x10 & 0xff));
uVar5 = FUN_005df4c4();
local_28._3_1_ = (byte)(uVar2 >> 0x18);
bVar3 = local_28._3_1_;
local_28._0_2_ = (undefined2)uVar2;
local_28._0_3_ = CONCAT12(uVar5,(undefined2)local_28);
local_1c = (float)((local_20 >> 8 & 0xff) - (uVar2 >> 8 & 0xff));
uVar5 = FUN_005df4c4();
uVar2 = (uint)(uint3)local_28;
local_1c = (float)((local_20 & 0xff) - (uVar2 & 0xff));
uVar6 = FUN_005df4c4();
local_28 = CONCAT31(CONCAT21(local_28._2_2_,uVar5),uVar6);
local_1c = (float)((uint)(uVar4 >> 8) - (uint)bVar3);
uVar5 = FUN_005df4c4();
local_28 = CONCAT13(uVar5,(uint3)local_28);
local_20 = local_28;
local_24 = local_24 - (local_24 - DAT_008427ac) * _DAT_008427b8;
_DAT_008427b8 = _DAT_008427b8 + _DAT_007c7208;
}
}
FUN_00505f30(local_24,local_20,local_c,local_18);
}
_DAT_008427a0 = _DAT_007c7200;
if (DAT_0084247c != 0) {
_DAT_008427a0 = *(double *)(*(int *)(DAT_0084247c + 0x50) + 0x10);
}
_DAT_008427a0 = _DAT_008427a0 + local_14;
}
FUN_005a4010(DAT_0081dbf8 == '\0');
if (DAT_0081dbf8 != '\0') {
FUN_005a3f90(DAT_0081dbf8);
iVar7 = FUN_004ff480(fVar1,&local_1c,&local_24,&local_20);
uVar2 = DAT_00842784;
if (iVar7 != 0) {
if (DAT_008427a9 != '\0') {
if (_DAT_007938b0 <= _DAT_008427b8) {
local_1c = DAT_008427b0;
local_24 = DAT_008427b4;
local_20 = DAT_00842784;
}
else {
uVar4 = local_20._2_2_;
local_18 = (local_20._2_2_ & 0xff) - (DAT_00842784 >> 0x10 & 0xff);
uVar5 = FUN_005df4c4();
local_28._3_1_ = (byte)(uVar2 >> 0x18);
bVar3 = local_28._3_1_;
local_28._0_2_ = (undefined2)uVar2;
local_28._0_3_ = CONCAT12(uVar5,(undefined2)local_28);
local_18 = (local_20 >> 8 & 0xff) - (uVar2 >> 8 & 0xff);
uVar5 = FUN_005df4c4();
uVar2 = (uint)(uint3)local_28;
local_18 = (local_20 & 0xff) - (uVar2 & 0xff);
uVar6 = FUN_005df4c4();
local_28 = CONCAT31(CONCAT21(local_28._2_2_,uVar5),uVar6);
local_18 = (uint)(uVar4 >> 8) - (uint)bVar3;
uVar5 = FUN_005df4c4();
local_28 = CONCAT13(uVar5,(uint3)local_28);
local_1c = local_1c - (local_1c - DAT_008427b0) * _DAT_008427b8;
local_24 = local_24 - (local_24 - DAT_008427b4) * _DAT_008427b8;
_DAT_008427b8 = _DAT_008427b8 + _DAT_007c7208;
local_20 = local_28;
}
}
FUN_005a41b0(&local_20,local_1c,local_24);
return;
}
}
}
}
return;
}
// --- FUN_005066d0 at 0x005066D0 (size: 347) ---
void __thiscall FUN_005066d0(int *param_1,int param_2,int param_3)
{
uint uVar1;
uint uVar2;
int iVar3;
uint uVar4;
int iVar5;
uint uVar6;
uint local_18;
uint local_14;
uint local_10;
uint local_c;
if (param_2 != 0) {
local_18 = param_1[4];
uVar4 = local_14;
uVar6 = local_14;
if (local_18 != 0) {
uVar4 = (local_18 >> 0x10 & 0xff) << 3;
uVar6 = local_18 >> 0x15 & 0x7f8;
}
FUN_00497d70(param_2,&local_18,&local_14);
uVar2 = local_14;
uVar1 = local_18;
iVar5 = (int)((*param_1 * 8 - uVar6) + local_18) >> 3;
iVar3 = (int)((*param_1 * 8 - uVar4) + local_14) >> 3;
param_1[6] = iVar5;
param_1[7] = iVar3;
if ((((iVar5 < param_1[1]) && (iVar3 < param_1[1])) && (-1 < iVar5)) && (-1 < iVar3)) {
if (param_3 != 0) {
FUN_005056b0();
}
local_10 = uVar1 & 7;
local_c = uVar2 & 7;
local_18 = 0;
if (0 < param_1[1]) {
do {
iVar3 = 0;
uVar4 = local_18;
if (0 < param_1[1]) {
do {
iVar5 = *(int *)(param_1[2] + (param_1[1] * uVar4 + iVar3) * 4);
if (iVar5 != 0) {
local_14 = FUN_005aab50(uVar4 - param_1[6],iVar3 - param_1[7]);
FUN_00505ec0(iVar5,local_18,iVar3);
thunk_FUN_005301e0(local_14,&local_10);
uVar4 = local_18;
}
iVar3 = iVar3 + 1;
} while (iVar3 < param_1[1]);
}
local_18 = uVar4 + 1;
} while ((int)local_18 < param_1[1]);
return;
}
}
else {
FUN_00506d30(0);
}
}
return;
}
// --- FUN_00506830 at 0x00506830 (size: 100) ---
void FUN_00506830(uint param_1)
{
undefined4 uVar1;
int iVar2;
uVar1 = FUN_004220b0(param_1,1);
iVar2 = FUN_00415430(uVar1);
if (iVar2 != 0) {
if (param_1 != 0) {
*(uint *)(iVar2 + 0x98) = param_1 >> 0x15 & 0x7f8;
*(uint *)(iVar2 + 0x9c) = (param_1 >> 0x10 & 0xff) << 3;
return;
}
*(undefined4 *)(iVar2 + 0x98) = 0;
*(undefined4 *)(iVar2 + 0x9c) = 0;
}
return;
}
// --- FUN_005068a0 at 0x005068A0 (size: 196) ---
uint __thiscall FUN_005068a0(int *param_1,uint param_2)
{
int iVar1;
int iVar2;
uint uVar3;
int iVar4;
int iVar5;
int local_c;
int local_8;
int local_4;
uVar3 = param_2;
iVar1 = param_1[2];
if (iVar1 == 0) {
return 0;
}
iVar4 = FUN_00497c80(param_2);
if ((iVar4 != 0) && ((uVar3 & 0xffff) < 0x100)) {
FUN_0043d820(param_1[4],&param_2,&local_8);
FUN_00497d70(uVar3,&local_c,&local_4);
iVar5 = (int)((*param_1 * 8 - param_2) + local_c) >> 3;
iVar4 = (*param_1 * 8 - local_8) + local_4 >> 3;
if (((-1 < iVar5) && (((-1 < iVar4 && (iVar2 = param_1[1], iVar5 < iVar2)) && (iVar4 < iVar2))))
&& (uVar3 = *(uint *)(iVar1 + (iVar2 * iVar5 + iVar4) * 4), uVar3 != 0)) {
return (*(int *)(uVar3 + 0x48) != 8) - 1 & uVar3;
}
}
return 0;
}
// --- FUN_00506970 at 0x00506970 (size: 106) ---
int FUN_00506970(uint param_1)
{
uint uVar1;
int iVar2;
uint local_4;
uVar1 = param_1;
iVar2 = FUN_005068a0(param_1);
if (iVar2 == 0) {
return 0;
}
FUN_00497d70(uVar1,&param_1,&local_4);
param_1 = param_1 & 0x80000007;
if ((int)param_1 < 0) {
param_1 = (param_1 - 1 | 0xfffffff8) + 1;
}
local_4 = local_4 & 0x80000007;
if ((int)local_4 < 0) {
local_4 = (local_4 - 1 | 0xfffffff8) + 1;
}
return (*(int *)(iVar2 + 0x48) * param_1 + local_4) * 0x108 + *(int *)(iVar2 + 0x90);
}
// --- FUN_005069e0 at 0x005069E0 (size: 681) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __fastcall FUN_005069e0(int param_1)
{
bool bVar1;
void *pvVar2;
void *pvVar3;
int iVar4;
int iVar5;
uint uVar6;
int iVar7;
int iVar8;
int local_18;
int local_14;
int local_10;
iVar7 = *(int *)(param_1 + 4);
local_14 = 0;
if (0 < iVar7) {
do {
iVar5 = 0;
if (0 < iVar7) {
do {
iVar7 = *(int *)(*(int *)(param_1 + 8) + (iVar7 * local_14 + iVar5) * 4);
iVar4 = 0;
if ((iVar7 != 0) &&
(*(undefined4 *)(iVar7 + 0xfc) = 0, 0 < *(int *)(iVar7 + 0x48) * *(int *)(iVar7 + 0x48)
)) {
iVar8 = 0;
do {
*(undefined4 *)(*(int *)(iVar7 + 0x90) + 0x104 + iVar8) = 0;
iVar4 = iVar4 + 1;
iVar8 = iVar8 + 0x108;
} while (iVar4 < *(int *)(iVar7 + 0x48) * *(int *)(iVar7 + 0x48));
}
iVar7 = *(int *)(param_1 + 4);
iVar5 = iVar5 + 1;
} while (iVar5 < iVar7);
}
iVar7 = *(int *)(param_1 + 4);
local_14 = local_14 + 1;
} while (local_14 < iVar7);
}
iVar7 = 0;
if (DAT_00842790 != (void *)0x0) {
if (DAT_00842960 == *(int *)(param_1 + 4)) goto LAB_00506a9e;
operator_delete__(DAT_00842790);
}
DAT_00842790 = (void *)thunk_FUN_005df0f5((*(int *)(param_1 + 4) + 1) * 0x100);
DAT_00842960 = *(int *)(param_1 + 4);
LAB_00506a9e:
bVar1 = false;
local_10 = 0;
if (DAT_00867330 == 0) {
local_18 = 0;
}
else {
local_18 = *(int *)(DAT_00867330 + 0x38);
}
do {
if (local_18 == 0) {
LAB_00506aea:
bVar1 = true;
}
else {
FUN_0054dcf0(DAT_00867330 + 0x10,iVar7);
iVar7 = iVar7 + 1;
local_10 = iVar7;
if (iVar7 == local_18) goto LAB_00506aea;
}
iVar5 = 0;
if (*(int *)(param_1 + 4) != -1 && -1 < *(int *)(param_1 + 4) + 1) {
iVar4 = 0;
do {
FUN_0054dc00((float)-*(int *)(param_1 + 0x18) * _DAT_00842824,
(float)(iVar5 - *(int *)(param_1 + 0x1c)) * _DAT_00842824,
iVar4 + (int)DAT_00842790);
iVar5 = iVar5 + 1;
iVar4 = iVar4 + 0x80;
} while (iVar5 < *(int *)(param_1 + 4) + 1);
}
iVar5 = *(int *)(param_1 + 4);
uVar6 = 0;
if (0 < iVar5) {
do {
iVar7 = 0;
iVar5 = iVar5 + 1;
if (0 < iVar5) {
do {
FUN_0054dc00((float)(int)((uVar6 - *(int *)(param_1 + 0x18)) + 1) * _DAT_00842824,
(float)(iVar7 - *(int *)(param_1 + 0x1c)) * _DAT_00842824,
(void *)(((uVar6 - 1 & 1) * iVar5 + iVar7) * 0x80 + (int)DAT_00842790));
iVar7 = iVar7 + 1;
iVar5 = *(int *)(param_1 + 4) + 1;
} while (iVar7 < iVar5);
}
iVar7 = *(int *)(param_1 + 4);
iVar5 = 0;
if (0 < iVar7) {
do {
iVar4 = *(int *)(*(int *)(param_1 + 8) + (iVar7 * uVar6 + iVar5) * 4);
if ((iVar4 != 0) &&
(pvVar3 = (void *)(((uVar6 - 1 & 1) * (iVar7 + 1) + iVar5) * 0x80 + (int)DAT_00842790
),
pvVar2 = (void *)((int)DAT_00842790 + ((uVar6 & 1) * (iVar7 + 1) + iVar5) * 0x80),
iVar7 = FUN_0054e860(pvVar2,(int)pvVar2 + 0x80,pvVar3,(int)pvVar3 + 0x80,
*(undefined4 *)(iVar4 + 0xe0),*(undefined4 *)(iVar4 + 0xe4)),
iVar7 != 0)) {
*(int *)(iVar4 + 0xfc) = iVar7;
FUN_00505b00(iVar4);
}
iVar7 = *(int *)(param_1 + 4);
iVar5 = iVar5 + 1;
} while (iVar5 < iVar7);
}
iVar5 = *(int *)(param_1 + 4);
uVar6 = uVar6 + 1;
iVar7 = local_10;
} while ((int)uVar6 < iVar5);
}
if (bVar1) {
return;
}
} while( true );
}
// --- FUN_00506c90 at 0x00506C90 (size: 146) ---
int FUN_00506c90(int param_1)
{
int iVar1;
undefined4 uVar2;
int iVar3;
undefined4 *puVar4;
puVar4 = &param_1;
iVar1 = param_1;
FUN_006b5980(puVar4,param_1);
FUN_00503770(puVar4,iVar1);
if (param_1 == DAT_0084282c) {
return 0;
}
iVar1 = FUN_00536fb0(4);
if (iVar1 != 0) {
uVar2 = FUN_004220b0(param_1,0xb);
iVar3 = FUN_00415430(uVar2);
if (iVar3 != 0) {
FUN_00537090(iVar3,4);
*(uint *)(iVar1 + 0x58) = *(uint *)(iVar1 + 0x58) | 0x20000;
return iVar1;
}
FUN_00536c10(iVar1);
}
return 0;
}
// --- FUN_00506d30 at 0x00506D30 (size: 88) ---
void __thiscall FUN_00506d30(int param_1,uint param_2)
{
uint uVar1;
if ((param_2 == 0) || (*(int *)(param_1 + 0x10) == 0)) {
*(undefined4 *)(param_1 + 0x14) = 0;
if (*(void **)(param_1 + 0xc) != (void *)0x0) {
operator_delete__(*(void **)(param_1 + 0xc));
*(undefined4 *)(param_1 + 0xc) = 0;
}
}
else {
uVar1 = *(uint *)(param_1 + 0x14);
if (param_2 != uVar1) {
*(uint *)(param_1 + 0x14) = param_2;
FUN_005066d0(param_2,((uVar1 ^ param_2) & 0xffff0000) != 0);
return;
}
}
return;
}
// --- FUN_00506d90 at 0x00506D90 (size: 109) ---
void __fastcall FUN_00506d90(int param_1)
{
int iVar1;
int iVar2;
if (*(int *)(param_1 + 0x20) != 0) {
FUN_00507a50(0);
}
if (*(int *)(param_1 + 0xc) != 0) {
FUN_005069e0();
iVar2 = *(int *)(param_1 + 4) * *(int *)(param_1 + 4);
while (iVar2 = iVar2 + -1, -1 < iVar2) {
iVar1 = *(int *)(*(int *)(param_1 + 0xc) + iVar2 * 4);
if ((iVar1 != 0) && (*(int *)(iVar1 + 0xfc) != 0)) {
(**(code **)(*DAT_00870340 + 0x50))(iVar1);
}
}
if ((*(int *)(param_1 + 0x20) != 0) && (DAT_0081dbf9 != '\0')) {
FUN_00507a50(1);
}
}
return;
}
// --- FUN_00506e00 at 0x00506E00 (size: 1931) ---
void __thiscall FUN_00506e00(int *param_1,uint param_2,uint param_3,int param_4,uint param_5)
{
int iVar1;
undefined4 *puVar2;
undefined4 uVar3;
int iVar4;
uint uVar5;
uint uVar6;
uint uVar7;
int iVar8;
int iVar9;
uint local_10;
uint local_c;
undefined1 local_8 [8];
FUN_00497d70(param_2,&local_c,&param_2);
param_2 = param_2 + *param_1 * -8;
uVar7 = local_c + *param_1 * -8;
iVar9 = 0;
if (((((param_1[2] == 0) || (param_5 != 0)) || (iVar8 = param_1[1], iVar8 <= (int)param_3)) ||
((iVar8 <= param_4 || ((int)param_3 <= -iVar8)))) || (param_4 <= -iVar8)) {
FUN_005055c0();
if (param_1[2] == 0) {
iVar9 = thunk_FUN_005df0f5(param_1[1] * param_1[1] * 4);
param_1[2] = iVar9;
}
param_4 = 0;
if (0 < param_1[1]) {
do {
param_3 = uVar7;
iVar9 = 0;
uVar7 = param_2;
if (0 < param_1[1]) {
do {
if ((((int)param_3 < 0) || ((int)uVar7 < 0)) ||
((0x7f7 < (int)param_3 || (0x7f7 < (int)uVar7)))) {
*(undefined4 *)(param_1[2] + (param_1[1] * param_4 + iVar9) * 4) = 0;
}
else {
uVar5 = ((param_3 & 0xfffffff8) << 5 | (int)uVar7 >> 3) << 0x10;
uVar6 = uVar5 | 0xffff;
param_5 = uVar6;
uVar3 = FUN_004220b0(uVar6,1);
iVar8 = FUN_00415430(uVar3);
if (iVar8 != 0) {
if (uVar6 != 0) {
local_10 = (uVar5 & 0xff000000) >> 0x15;
local_c = (param_5 >> 0x10 & 0xff) << 3;
}
*(uint *)(iVar8 + 0x98) = local_10;
*(uint *)(iVar8 + 0x9c) = local_c;
}
*(int *)(param_1[2] + (param_1[1] * param_4 + iVar9) * 4) = iVar8;
}
iVar9 = iVar9 + 1;
uVar7 = uVar7 + 8;
} while (iVar9 < param_1[1]);
}
param_4 = param_4 + 1;
param_3 = param_3 + 8;
uVar7 = param_3;
} while (param_4 < param_1[1]);
}
}
else {
if (param_3 == 0) {
if (param_4 == 0) {
param_4 = 0;
if (0 < iVar8) {
do {
param_5 = uVar7;
iVar9 = 0;
if (0 < param_1[1]) {
param_3 = param_2;
do {
iVar4 = param_1[2];
iVar8 = param_1[1] * param_4 + iVar9;
if (*(int *)(iVar4 + iVar8 * 4) == 0) {
iVar1 = FUN_0043d7f0(param_5,param_3);
if (iVar1 == 0) {
*(undefined4 *)(iVar4 + iVar8 * 4) = 0;
}
else {
puVar2 = (undefined4 *)FUN_00505d80(&local_c,param_5,param_3);
uVar3 = FUN_00506830(*puVar2);
*(undefined4 *)(param_1[2] + iVar8 * 4) = uVar3;
}
}
iVar9 = iVar9 + 1;
param_3 = param_3 + 8;
} while (iVar9 < param_1[1]);
}
param_4 = param_4 + 1;
param_5 = param_5 + 8;
uVar7 = param_5;
} while (param_4 < param_1[1]);
}
goto LAB_005074c7;
}
}
else if ((int)param_3 < 0) {
iVar8 = iVar8 + -1;
if (param_4 < 0) {
if (-1 < iVar8) {
local_10 = uVar7 + iVar8 * 8;
do {
iVar9 = param_1[1] + -1;
if (-1 < iVar9) {
param_5 = iVar9 + param_4;
local_c = param_2 + iVar9 * 8;
do {
uVar7 = param_3;
iVar4 = param_1[1];
if ((((int)(iVar4 + param_3) <= iVar8) || (iVar4 + param_4 <= iVar9)) &&
(*(int *)(param_1[2] + (iVar4 * iVar8 + iVar9) * 4) != 0)) {
FUN_00530a30();
}
if (((int)(uVar7 + iVar8) < 0) || ((int)param_5 < 0)) {
iVar4 = FUN_0043d7f0(local_10,local_c);
if (iVar4 == 0) {
*(undefined4 *)(param_1[2] + (param_1[1] * iVar8 + iVar9) * 4) = 0;
}
else {
puVar2 = (undefined4 *)FUN_00505d80(local_8,local_10,local_c);
iVar4 = param_1[1];
uVar3 = FUN_00506830(*puVar2);
*(undefined4 *)(param_1[2] + (iVar4 * iVar8 + iVar9) * 4) = uVar3;
}
}
else {
*(undefined4 *)(param_1[2] + (param_1[1] * iVar8 + iVar9) * 4) =
*(undefined4 *)(param_1[2] + (param_1[1] * (uVar7 + iVar8) + param_5) * 4);
}
iVar9 = iVar9 + -1;
param_5 = param_5 - 1;
local_c = local_c - 8;
} while (-1 < iVar9);
}
iVar8 = iVar8 + -1;
local_10 = local_10 + -8;
} while (-1 < iVar8);
}
}
else if (-1 < iVar8) {
local_c = uVar7 + iVar8 * 8;
do {
iVar9 = 0;
if (0 < param_1[1]) {
param_5 = param_2;
do {
uVar7 = param_3;
if ((((int)(param_1[1] + param_3) <= iVar8) || (iVar9 < param_4)) &&
(*(int *)(param_1[2] + (param_1[1] * iVar8 + iVar9) * 4) != 0)) {
FUN_00530a30();
}
if (((int)(uVar7 + iVar8) < 0) || (iVar4 = param_1[1], iVar4 <= param_4 + iVar9)) {
iVar4 = FUN_0043d7f0(local_c,param_5);
if (iVar4 == 0) {
*(undefined4 *)(param_1[2] + (param_1[1] * iVar8 + iVar9) * 4) = 0;
}
else {
puVar2 = (undefined4 *)FUN_00505d80(local_8,local_c,param_5);
iVar4 = param_1[1];
uVar3 = FUN_00506830(*puVar2);
*(undefined4 *)(param_1[2] + (iVar4 * iVar8 + iVar9) * 4) = uVar3;
}
}
else {
*(undefined4 *)(param_1[2] + (iVar4 * iVar8 + iVar9) * 4) =
*(undefined4 *)(param_1[2] + (iVar4 * (uVar7 + iVar8) + param_4 + iVar9) * 4);
}
iVar9 = iVar9 + 1;
param_5 = param_5 + 8;
} while (iVar9 < param_1[1]);
}
iVar8 = iVar8 + -1;
local_c = local_c - 8;
} while (-1 < iVar8);
}
goto LAB_005074c7;
}
if (param_4 < 0) {
iVar9 = 0;
if (0 < iVar8) {
do {
local_c = uVar7;
iVar8 = param_1[1] + -1;
if (-1 < iVar8) {
param_5 = iVar8 + param_4;
local_10 = param_2 + iVar8 * 8;
do {
if (((iVar9 < (int)param_3) || (param_1[1] + param_4 <= iVar8)) &&
(*(int *)(param_1[2] + (param_1[1] * iVar9 + iVar8) * 4) != 0)) {
FUN_00530a30();
}
iVar4 = param_1[1];
if (((int)(param_3 + iVar9) < iVar4) && (-1 < (int)param_5)) {
*(undefined4 *)(param_1[2] + (iVar4 * iVar9 + iVar8) * 4) =
*(undefined4 *)(param_1[2] + (iVar4 * (param_3 + iVar9) + param_5) * 4);
}
else {
iVar1 = FUN_0043d7f0(local_c,local_10);
if (iVar1 == 0) {
*(undefined4 *)(param_1[2] + (iVar4 * iVar9 + iVar8) * 4) = 0;
}
else {
puVar2 = (undefined4 *)FUN_00505d80(local_8,local_c,local_10);
uVar3 = FUN_00506830(*puVar2);
*(undefined4 *)(param_1[2] + (iVar4 * iVar9 + iVar8) * 4) = uVar3;
}
}
iVar8 = iVar8 + -1;
param_5 = param_5 - 1;
local_10 = local_10 + -8;
} while (-1 < iVar8);
}
iVar9 = iVar9 + 1;
local_c = local_c + 8;
uVar7 = local_c;
} while (iVar9 < param_1[1]);
}
}
else {
local_10 = uVar7;
if (0 < iVar8) {
do {
iVar8 = 0;
if (0 < param_1[1]) {
param_5 = param_2;
do {
if (((iVar9 < (int)param_3) || (iVar8 < param_4)) &&
(*(int *)(param_1[2] + (param_1[1] * iVar9 + iVar8) * 4) != 0)) {
FUN_00530a30();
}
iVar4 = param_1[1];
local_c = param_3 + iVar9;
if (((int)local_c < iVar4) && (param_4 + iVar8 < iVar4)) {
*(undefined4 *)(param_1[2] + (iVar4 * iVar9 + iVar8) * 4) =
*(undefined4 *)(param_1[2] + (iVar4 * local_c + param_4 + iVar8) * 4);
}
else {
iVar1 = FUN_0043d7f0(local_10,param_5);
if (iVar1 == 0) {
*(undefined4 *)(param_1[2] + (iVar4 * iVar9 + iVar8) * 4) = 0;
}
else {
puVar2 = (undefined4 *)FUN_00505d80(local_8,local_10,param_5);
uVar3 = FUN_00506830(*puVar2);
*(undefined4 *)(param_1[2] + (iVar4 * iVar9 + iVar8) * 4) = uVar3;
}
}
iVar8 = iVar8 + 1;
param_5 = param_5 + 8;
} while (iVar8 < param_1[1]);
}
iVar9 = iVar9 + 1;
local_10 = local_10 + 8;
} while (iVar9 < param_1[1]);
}
}
}
LAB_005074c7:
param_4 = 0;
if (0 < param_1[1]) {
do {
iVar8 = 0;
iVar9 = param_4;
if (0 < param_1[1]) {
do {
iVar4 = *(int *)(param_1[2] + (param_1[1] * iVar9 + iVar8) * 4);
if (iVar4 != 0) {
FUN_005059f0(iVar9,iVar8,&param_3,&param_2);
if ((*(int *)(iVar4 + 0x48) == 8) && ((int)(8 / (longlong)(int)param_3) != 8)) {
FUN_00531000();
}
iVar1 = FUN_005338f0(*(undefined4 *)(iVar4 + 0x28),param_3,param_2);
iVar9 = param_4;
if (iVar1 != 0) {
*(undefined4 *)(iVar4 + 0xf4) = 0xffffffff;
*(undefined4 *)(iVar4 + 0xf8) = 0xffffffff;
FUN_00530150();
FUN_00532440();
FUN_0052ff10();
iVar9 = param_4;
}
}
iVar8 = iVar8 + 1;
} while (iVar8 < param_1[1]);
}
param_4 = iVar9 + 1;
} while (param_4 < param_1[1]);
}
return;
}
// --- FUN_005075a0 at 0x005075A0 (size: 360) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __thiscall FUN_005075a0(int param_1,int param_2,int param_3,int param_4,int param_5)
{
float fVar1;
int iVar2;
undefined4 uVar3;
if (DAT_0084247c == 0) {
return 0;
}
FUN_00505540();
uVar3 = 0;
FUN_006b5980(0);
iVar2 = FUN_005035e0(uVar3);
fVar1 = (float)iVar2;
if (iVar2 < 0) {
fVar1 = fVar1 + _DAT_0079920c;
}
FUN_0054c410(fVar1);
uVar3 = 2;
FUN_006b5980(2);
iVar2 = FUN_005035e0(uVar3);
fVar1 = (float)iVar2;
if (iVar2 < 0) {
fVar1 = fVar1 + _DAT_0079920c;
}
FUN_0054c420(fVar1);
uVar3 = 1;
FUN_006b5980(1);
iVar2 = FUN_005035e0(uVar3);
fVar1 = (float)iVar2;
if (iVar2 < 0) {
fVar1 = fVar1 + _DAT_0079920c;
}
FUN_0054c430(fVar1);
uVar3 = 3;
FUN_006b5980(3);
iVar2 = FUN_005035e0(uVar3);
fVar1 = (float)iVar2;
if (iVar2 < 0) {
fVar1 = fVar1 + _DAT_0079920c;
}
FUN_0054c440(fVar1);
if (param_2 != 0) {
uVar3 = FUN_00506c90(0);
*(undefined4 *)(param_1 + 0x24) = uVar3;
FUN_0054c3d0(uVar3);
}
if (param_4 != 0) {
uVar3 = FUN_00506c90(2);
*(undefined4 *)(param_1 + 0x28) = uVar3;
FUN_0054c3f0(uVar3);
}
if (param_3 != 0) {
uVar3 = FUN_00506c90(1);
*(undefined4 *)(param_1 + 0x2c) = uVar3;
FUN_0054c3e0(uVar3);
}
if (param_5 != 0) {
uVar3 = FUN_00506c90(3);
*(undefined4 *)(param_1 + 0x30) = uVar3;
FUN_0054c400(uVar3);
}
return 1;
}
// --- FUN_00507710 at 0x00507710 (size: 19) ---
void FUN_00507710(void)
{
FUN_005075a0(0,DAT_0081ffa5,DAT_0081ffa5,0);
return;
}
// --- FUN_00507730 at 0x00507730 (size: 232) ---
void __thiscall FUN_00507730(int param_1,uint param_2)
{
uint uVar1;
bool bVar2;
int iVar3;
int *piVar4;
int *piVar5;
int iVar6;
bool bVar7;
int local_8;
int local_4;
iVar6 = 0;
if (param_2 == 0) {
FUN_005055c0();
return;
}
iVar3 = FUN_005054c0(*(undefined4 *)(param_1 + 0x10),param_2,&local_8,&local_4);
piVar5 = *(int **)(param_1 + 8);
bVar7 = iVar3 == 0;
bVar2 = false;
if ((piVar5 != (int *)0x0) && (0 < *(int *)(param_1 + 4))) {
do {
iVar3 = 0;
piVar4 = piVar5;
do {
if (*piVar4 == 0) {
bVar2 = true;
goto LAB_005077b6;
}
iVar3 = iVar3 + 1;
piVar4 = piVar4 + 1;
} while (iVar3 < *(int *)(param_1 + 4));
iVar6 = iVar6 + 1;
piVar5 = piVar5 + *(int *)(param_1 + 4);
} while (iVar6 < *(int *)(param_1 + 4));
}
LAB_005077b6:
if ((((local_8 == 0) && (local_4 == 0)) && (*(int *)(param_1 + 8) != 0)) && ((!bVar7 && (!bVar2)))
) {
*(uint *)(param_1 + 0x10) = param_2;
return;
}
FUN_00506e00(param_2,local_8,local_4,bVar7);
uVar1 = *(uint *)(param_1 + 0x10);
*(uint *)(param_1 + 0x10) = param_2;
FUN_005066d0(*(undefined4 *)(param_1 + 0x14),((uVar1 ^ param_2) & 0xffff0000) != 0 || bVar7);
return;
}
// --- FUN_00507820 at 0x00507820 (size: 4) ---
int __fastcall FUN_00507820(int param_1)
{
return param_1 + 0x3c;
}
// --- FUN_00507830 at 0x00507830 (size: 261) ---
void __thiscall FUN_00507830(int param_1,int param_2)
{
int iVar1;
int iVar2;
uint uVar3;
(**(code **)(**(int **)(param_1 + 0x28) + 0x44))(*(undefined4 *)(param_2 + 4));
*(undefined4 *)(*(int *)(param_1 + 0x28) + 0x58) = *(undefined4 *)(param_2 + 4);
FUN_00425f10(param_2 + 8);
(**(code **)(**(int **)(param_1 + 0x24) + 0x44))(*(undefined4 *)(param_2 + 4));
*(undefined4 *)(*(int *)(param_1 + 0x24) + 0x58) = *(undefined4 *)(param_2 + 4);
FUN_00425f10(param_2 + 8);
uVar3 = 0;
if (*(int *)(param_1 + 0x14) != 0) {
do {
iVar1 = *(int *)(param_1 + 0xc);
iVar2 = *(int *)(iVar1 + uVar3 * 4);
if (iVar2 != 0) {
FUN_00425f10(iVar2 + 0x50);
if ((*(byte *)(*(int *)(param_1 + 0x18) + uVar3 * 4) & 4) == 0) {
FUN_00536030(*(int *)(iVar1 + uVar3 * 4) + 0x50,param_2 + 8,0);
}
else {
FUN_00507820();
}
FUN_00514b90(&stack0xffffffb8);
FUN_00511870(*(undefined4 *)(param_2 + 4));
}
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(param_1 + 0x14));
}
return;
}
// --- FUN_00507940 at 0x00507940 (size: 150) ---
int __thiscall FUN_00507940(int param_1,int param_2,float *param_3,int param_4,int param_5)
{
int iVar1;
if ((param_2 == 0) || ((param_5 != 0 && (DAT_0081dbf9 == '\0')))) {
return 0;
}
iVar1 = FUN_00514470(param_2,0,0);
if (iVar1 != 0) {
if ((*param_3 != DAT_00796344) || (param_3[1] != DAT_00796344)) {
FUN_005106f0(*param_3,param_3[1]);
}
if (param_4 != 0) {
FUN_005154e0(*(undefined4 *)(param_1 + 0x28));
return iVar1;
}
FUN_005154e0(*(undefined4 *)(param_1 + 0x24));
}
return iVar1;
}
// --- FUN_005079e0 at 0x005079E0 (size: 105) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void FUN_005079e0(undefined4 param_1,float param_2,float param_3)
{
undefined4 local_c;
float local_8;
undefined4 local_4;
if (param_2 != DAT_00796344) {
FUN_00536b80(param_2);
}
if (param_3 != DAT_00796344) {
local_8 = -param_3 * (float)_DAT_0079c6b0;
local_c = 0;
local_4 = 0;
FUN_005364e0(&local_c);
}
return;
}
// --- FUN_00507a50 at 0x00507A50 (size: 300) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_00507a50(int param_1,int param_2)
{
uint uVar1;
float fVar2;
int *piVar3;
char cVar4;
char cVar5;
int iVar6;
uint uVar7;
iVar6 = FUN_00451ec0();
piVar3 = DAT_00870340;
if ((iVar6 != 0) || (param_2 == 0)) {
*(undefined1 *)(DAT_00870340 + 0x1f8) = 1;
cVar4 = FUN_005a1560();
FUN_005a3f90(DAT_008427a9 != '\0');
fVar2 = DAT_0081fc98;
FUN_0054bf30(DAT_0081fc98 * _DAT_007c6f14);
FUN_005a3e20(8,0);
if (param_2 == 0) {
uVar7 = 0;
if (*(int *)(param_1 + 0x14) != 0) {
do {
if ((((*(int *)(*(int *)(param_1 + 0xc) + uVar7 * 4) != 0) &&
(uVar1 = *(uint *)(*(int *)(param_1 + 0x18) + uVar7 * 4), (uVar1 & 1) == 0)) &&
((DAT_0081dbf9 != '\0' || ((uVar1 & 4) == 0)))) &&
(((DAT_008427a9 == '\0' || (cVar5 = FUN_005a1560(), cVar5 == '\0')) ||
((*(byte *)(*(int *)(param_1 + 0x18) + uVar7 * 4) & 2) == 0)))) {
FUN_00511720();
FUN_00511760();
}
uVar7 = uVar7 + 1;
} while (uVar7 < *(uint *)(param_1 + 0x14));
}
}
else if (DAT_0081dbf9 != '\0') {
(**(code **)(*DAT_00870340 + 100))(*(undefined4 *)(param_1 + 0x28));
}
FUN_0054bf30(fVar2);
FUN_005a3e20(4,1);
FUN_005a3f90(cVar4 != '\0');
*(undefined1 *)(piVar3 + 0x1f8) = 0;
}
return;
}
// --- FUN_00507c50 at 0x00507C50 (size: 234) ---
undefined4 * __fastcall FUN_00507c50(undefined4 *param_1)
{
int iVar1;
undefined4 uVar2;
LONG LVar3;
int local_8;
int local_4;
*param_1 = 0;
param_1[1] = 0;
param_1[2] = 0;
param_1[3] = 0;
param_1[4] = 0;
param_1[5] = 0;
param_1[6] = 0;
param_1[7] = 0;
param_1[8] = 0;
iVar1 = FUN_005df0f5(0x148);
if (iVar1 == 0) {
uVar2 = 0;
}
else {
uVar2 = FUN_0052ce50();
}
param_1[9] = uVar2;
iVar1 = FUN_005df0f5(0x148);
if (iVar1 == 0) {
uVar2 = 0;
}
else {
uVar2 = FUN_0052ce50();
}
param_1[10] = uVar2;
FUN_00401340(
"Number of seconds to adjust Timer time to compute GameTime time. GameTime effects the state of the sky"
);
FUN_00401340("GameTime.TimeZeroDelta");
FUN_004369a0(&DAT_00842970,10,&local_8,&local_4,&LAB_00507b80,0,0,0);
LVar3 = InterlockedDecrement((LONG *)(local_8 + -0x10));
if ((LVar3 == 0) && ((undefined4 *)(local_8 + -0x14) != (undefined4 *)0x0)) {
(*(code *)**(undefined4 **)(local_8 + -0x14))(1);
}
LVar3 = InterlockedDecrement((LONG *)(local_4 + -0x10));
if ((LVar3 == 0) && ((undefined4 *)(local_4 + -0x14) != (undefined4 *)0x0)) {
(*(code *)**(undefined4 **)(local_4 + -0x14))(1);
}
return param_1;
}
// --- FUN_00507d40 at 0x00507D40 (size: 209) ---
void __fastcall FUN_00507d40(int *param_1)
{
undefined4 *puVar1;
LONG LVar2;
int *piVar3;
uint uVar4;
int iVar5;
int *local_4;
local_4 = param_1;
FUN_00401340("GameTime.TimeZeroDelta");
FUN_00436cf0(&local_4);
piVar3 = local_4 + -5;
LVar2 = InterlockedDecrement(local_4 + -4);
if ((LVar2 == 0) && (piVar3 != (int *)0x0)) {
(**(code **)*piVar3)(1);
}
uVar4 = 0;
if (param_1[5] != 0) {
do {
if (*(int *)(param_1[3] + uVar4 * 4) != 0) {
if ((*(byte *)(param_1[6] + uVar4 * 4) & 1) == 0) {
iVar5 = param_1[9];
}
else {
iVar5 = param_1[10];
}
FUN_00513ef0(iVar5);
puVar1 = *(undefined4 **)(param_1[3] + uVar4 * 4);
if (puVar1 != (undefined4 *)0x0) {
(**(code **)*puVar1)(1);
}
}
uVar4 = uVar4 + 1;
} while (uVar4 < (uint)param_1[5]);
}
if ((int *)param_1[9] != (int *)0x0) {
(**(code **)(*(int *)param_1[9] + 0x18))(1);
}
if ((int *)param_1[10] != (int *)0x0) {
(**(code **)(*(int *)param_1[10] + 0x18))(1);
}
operator_delete__((void *)param_1[6]);
operator_delete__((void *)param_1[3]);
if (*param_1 != 0) {
operator_delete__((void *)(*param_1 + -4));
}
return;
}
// --- FUN_00507e20 at 0x00507E20 (size: 494) ---
void __fastcall FUN_00507e20(int *param_1)
{
int iVar1;
uint uVar2;
undefined4 *puVar3;
int iVar4;
int *piVar5;
undefined4 uVar6;
uint uVar7;
bool bVar8;
int iVar9;
uint uStack_8;
undefined1 auStack_4 [4];
bVar8 = DAT_0081dd3c != DAT_0081dbf9;
uStack_8 = param_1[5];
uVar2 = param_1[2];
DAT_0081dd3c = DAT_0081dbf9;
for (uVar7 = uVar2; uVar7 < uStack_8; uVar7 = uVar7 + 1) {
if (*(int *)(param_1[3] + uVar7 * 4) != 0) {
if ((*(byte *)(param_1[6] + uVar7 * 4) & 1) == 0) {
iVar4 = param_1[9];
}
else {
iVar4 = param_1[10];
}
FUN_00513ef0(iVar4);
puVar3 = *(undefined4 **)(param_1[3] + uVar7 * 4);
if (puVar3 != (undefined4 *)0x0) {
(**(code **)*puVar3)(1);
}
*(undefined4 *)(param_1[3] + uVar7 * 4) = 0;
}
}
if (uStack_8 < uVar2) {
FUN_00500570(uVar2);
FUN_00500570(uVar2);
if (uStack_8 < uVar2) {
uStack_8 = uVar2 - uStack_8;
do {
uVar7 = param_1[4];
if ((uint)param_1[5] < uVar7) {
LAB_00507ee6:
*(undefined4 *)(param_1[3] + param_1[5] * 4) = 0;
param_1[5] = param_1[5] + 1;
}
else {
if (uVar7 == 0) {
iVar4 = 8;
}
else {
iVar4 = uVar7 * 2;
}
iVar4 = FUN_00500570(iVar4);
if (iVar4 != 0) goto LAB_00507ee6;
}
uVar7 = param_1[7];
if ((uint)param_1[8] < uVar7) {
LAB_00507f16:
*(undefined4 *)(param_1[6] + param_1[8] * 4) = 0;
param_1[8] = param_1[8] + 1;
}
else {
if (uVar7 == 0) {
iVar4 = 8;
}
else {
iVar4 = uVar7 * 2;
}
iVar4 = FUN_00500570(iVar4);
if (iVar4 != 0) goto LAB_00507f16;
}
uStack_8 = uStack_8 + -1;
} while (uStack_8 != 0);
}
}
uStack_8 = 0;
if (uVar2 != 0) {
iVar4 = 0;
do {
iVar1 = uStack_8 * 4;
if (*(int *)(param_1[3] + iVar1) == 0) {
LAB_00507fb6:
*(undefined4 *)(iVar1 + param_1[6]) = *(undefined4 *)(iVar4 + 0x28 + *param_1);
iVar9 = param_1[3];
uVar6 = FUN_00507940(*(undefined4 *)(iVar4 + *param_1),iVar4 + *param_1 + 0x10,
*(uint *)(iVar1 + param_1[6]) & 1,*(uint *)(iVar1 + param_1[6]) & 4);
*(undefined4 *)(iVar9 + iVar1) = uVar6;
}
else {
piVar5 = (int *)FUN_0050f460(auStack_4);
if (((*(int *)(iVar4 + *param_1) != *piVar5) ||
(*(uint *)(iVar1 + param_1[6]) != ((int *)(iVar4 + *param_1))[10])) ||
((bVar8 && ((*(uint *)(iVar1 + param_1[6]) & 4) != 0)))) {
if ((*(byte *)(iVar1 + param_1[6]) & 1) == 0) {
iVar9 = param_1[9];
}
else {
iVar9 = param_1[10];
}
FUN_00513ef0(iVar9);
if (*(undefined4 **)(iVar1 + param_1[3]) != (undefined4 *)0x0) {
(**(code **)**(undefined4 **)(iVar1 + param_1[3]))(1);
}
goto LAB_00507fb6;
}
}
uStack_8 = uStack_8 + 1;
iVar4 = iVar4 + 0x2c;
} while (uStack_8 < uVar2);
}
return;
}
// --- FUN_00508010 at 0x00508010 (size: 432) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __fastcall FUN_00508010(int *param_1)
{
float fVar1;
uint uVar2;
undefined4 uVar3;
undefined4 uVar4;
int iVar5;
int iVar6;
uint uVar7;
undefined4 local_48;
undefined4 local_44;
undefined4 local_40;
undefined4 local_3c;
undefined4 local_14;
undefined4 local_10;
undefined4 local_c;
FUN_004ff420();
if (DAT_008ee9c8 == 0) {
fVar1 = (float)_DAT_00795610;
}
else {
fVar1 = *(float *)(DAT_008ee9c8 + 0x48);
}
iVar6 = FUN_004ff4b0(fVar1,param_1);
if (iVar6 != 0) {
FUN_00507e20();
uVar2 = param_1[2];
uVar7 = 0;
if (uVar2 != 0) {
iVar6 = 0;
do {
if (*(int *)(param_1[3] + uVar7 * 4) != 0) {
uVar3 = *(undefined4 *)(iVar6 + 8 + *param_1);
uVar4 = *(undefined4 *)(iVar6 + *param_1 + 0xc);
local_48 = 0x3f800000;
local_44 = 0;
local_40 = 0;
local_3c = 0;
local_14 = 0;
local_10 = 0;
local_c = 0;
FUN_00535b30();
if ((*(byte *)(param_1[6] + uVar7 * 4) & 4) != 0) {
iVar5 = *(int *)param_1[3];
local_14 = *(undefined4 *)(iVar5 + 0x84);
local_10 = *(undefined4 *)(iVar5 + 0x88);
local_c = *(undefined4 *)(iVar5 + 0x8c);
}
FUN_005079e0(&local_48,uVar3,uVar4);
FUN_00514b90(&local_48);
if (DAT_00796344 < *(float *)(iVar6 + 0x20 + *param_1)) {
FUN_00512360(0,*(float *)(iVar6 + 0x20 + *param_1) * _DAT_007a1870,0,0);
}
if (DAT_00796344 < *(float *)(iVar6 + 0x24 + *param_1)) {
FUN_005124b0(0,*(float *)(iVar6 + 0x24 + *param_1) * _DAT_007a1870,0,0);
}
if (DAT_00796344 <= *(float *)(iVar6 + 0x1c + *param_1)) {
FUN_005120c0(*(float *)(iVar6 + 0x1c + *param_1) * _DAT_007a1870,0,0);
}
}
uVar7 = uVar7 + 1;
iVar6 = iVar6 + 0x2c;
} while (uVar7 < uVar2);
}
}
return;
}
// --- FUN_005081c0 at 0x005081C0 (size: 49) ---
void __fastcall FUN_005081c0(int *param_1)
{
param_1[2] = 0;
param_1[1] = 0;
if (*param_1 != 0) {
operator_delete__((void *)(*param_1 + -4));
}
*param_1 = 0;
FUN_00507e20();
return;
}
// --- FUN_00508200 at 0x00508200 (size: 90) ---
void __thiscall FUN_00508200(int *param_1,uint param_2)
{
int iVar1;
uint uVar2;
if (param_2 <= (uint)param_1[3]) {
FUN_00508290(param_2);
return;
}
iVar1 = thunk_FUN_005df0f5(param_2 * 4);
uVar2 = 0;
if (param_1[3] != 0) {
do {
*(undefined4 *)(iVar1 + uVar2 * 4) = *(undefined4 *)(*param_1 + uVar2 * 4);
uVar2 = uVar2 + 1;
} while (uVar2 < (uint)param_1[3]);
}
operator_delete__((void *)*param_1);
*param_1 = iVar1;
param_1[3] = param_2;
return;
}
// --- FUN_00508260 at 0x00508260 (size: 44) ---
undefined4 * __thiscall FUN_00508260(undefined4 *param_1,byte param_2)
{
*param_1 = &PTR_FUN_007c7444;
operator_delete__((void *)param_1[1]);
if ((param_2 & 1) != 0) {
operator_delete(param_1);
}
return param_1;
}
// --- FUN_00508290 at 0x00508290 (size: 123) ---
void __thiscall FUN_00508290(int *param_1,uint param_2)
{
int iVar1;
uint uVar2;
if (param_2 <= (uint)param_1[3]) {
if (param_2 == 0) {
param_1[3] = 0;
operator_delete__((void *)*param_1);
*param_1 = 0;
}
else {
iVar1 = thunk_FUN_005df0f5(param_2 * 4);
uVar2 = 0;
param_1[3] = param_2;
if (param_2 != 0) {
do {
*(undefined4 *)(iVar1 + uVar2 * 4) = *(undefined4 *)(*param_1 + uVar2 * 4);
uVar2 = uVar2 + 1;
} while (uVar2 < (uint)param_1[3]);
}
operator_delete__((void *)*param_1);
*param_1 = iVar1;
}
if (param_2 < (uint)param_1[2]) {
param_1[2] = param_2;
}
return;
}
FUN_00508200(param_2);
return;
}
// --- FUN_00508310 at 0x00508310 (size: 73) ---
void __fastcall FUN_00508310(int param_1)
{
undefined4 *puVar1;
uint uVar2;
int iVar3;
undefined4 *puVar4;
undefined4 *puVar5;
puVar1 = (undefined4 *)thunk_FUN_005df0f5(*(int *)(param_1 + 0xc) << 5);
puVar4 = *(undefined4 **)(param_1 + 4);
puVar5 = puVar1;
for (uVar2 = (uint)(*(int *)(param_1 + 0xc) << 4) >> 2; uVar2 != 0; uVar2 = uVar2 - 1) {
*puVar5 = *puVar4;
puVar4 = puVar4 + 1;
puVar5 = puVar5 + 1;
}
for (iVar3 = 0; iVar3 != 0; iVar3 = iVar3 + -1) {
*(undefined1 *)puVar5 = *(undefined1 *)puVar4;
puVar4 = (undefined4 *)((int)puVar4 + 1);
puVar5 = (undefined4 *)((int)puVar5 + 1);
}
*(int *)(param_1 + 0xc) = *(int *)(param_1 + 0xc) << 1;
operator_delete__(*(void **)(param_1 + 4));
*(undefined4 **)(param_1 + 4) = puVar1;
return;
}
// --- FUN_00508420 at 0x00508420 (size: 65) ---
int __thiscall FUN_00508420(int param_1,int param_2)
{
int iVar1;
int *piVar2;
uint uVar3;
int *piVar4;
uVar3 = 0;
if (*(int *)(param_1 + 8) != 0) {
piVar2 = *(int **)(param_1 + 0xc);
piVar4 = piVar2;
do {
if (*piVar4 == param_2) {
iVar1 = *(int *)(param_1 + 8) + -1;
*(int *)(param_1 + 8) = iVar1;
piVar2[uVar3] = piVar2[iVar1];
return param_2;
}
uVar3 = uVar3 + 1;
piVar4 = piVar4 + 1;
} while (uVar3 < *(uint *)(param_1 + 8));
}
return 0;
}
// --- FUN_00508470 at 0x00508470 (size: 120) ---
void __thiscall FUN_00508470(int param_1,double param_2,undefined4 param_3)
{
double *pdVar1;
int iVar2;
int iVar3;
undefined4 *puVar4;
undefined4 *puVar5;
int iVar6;
if (*(int *)(param_1 + 8) == *(int *)(param_1 + 0xc)) {
FUN_00508310();
}
iVar6 = *(int *)(param_1 + 4) + -0x10;
iVar2 = *(int *)(param_1 + 8) + 1;
*(int *)(param_1 + 8) = iVar2;
while (1 < iVar2) {
iVar3 = (iVar2 >> 1) * 0x10;
puVar4 = (undefined4 *)(iVar3 + iVar6);
if (*(double *)(iVar3 + iVar6) <= param_2) break;
puVar5 = (undefined4 *)(iVar2 * 0x10 + iVar6);
*puVar5 = *puVar4;
puVar5[1] = puVar4[1];
puVar5[2] = puVar4[2];
puVar5[3] = puVar4[3];
iVar2 = iVar2 >> 1;
}
pdVar1 = (double *)(iVar2 * 0x10 + iVar6);
*pdVar1 = param_2;
*(undefined4 *)(pdVar1 + 1) = param_3;
return;
}
// --- FUN_005084f0 at 0x005084F0 (size: 127) ---
undefined4 __thiscall FUN_005084f0(int param_1,undefined4 *param_2,undefined4 *param_3)
{
undefined4 *puVar1;
int iVar2;
undefined4 *puVar3;
if ((0 < *(int *)(param_1 + 8)) &&
(puVar1 = *(undefined4 **)(param_1 + 4), puVar1 != (undefined4 *)0x0)) {
*param_2 = *puVar1;
param_2[1] = puVar1[1];
*param_3 = *(undefined4 *)(*(int *)(param_1 + 4) + 8);
if (1 < *(int *)(param_1 + 8)) {
puVar1 = *(undefined4 **)(param_1 + 4);
iVar2 = *(int *)(param_1 + 8) + -1;
*(int *)(param_1 + 8) = iVar2;
puVar3 = puVar1 + iVar2 * 4;
*puVar1 = *puVar3;
puVar1[1] = puVar3[1];
puVar1[2] = puVar3[2];
puVar1[3] = puVar3[3];
FUN_00541840(1);
return 1;
}
*(undefined4 *)(param_1 + 8) = 0;
FUN_00541840(1);
return 1;
}
return 0;
}
// --- FUN_00508570 at 0x00508570 (size: 64) ---
undefined4 * __thiscall FUN_00508570(undefined4 *param_1,byte param_2)
{
*param_1 = &PTR_FUN_007c7448;
if ((undefined4 *)param_1[0x18] != param_1 + 1) {
operator_delete__((undefined4 *)param_1[0x18]);
}
param_1[0x18] = 0;
param_1[0x19] = 0;
param_1[0x1a] = 0;
param_1[0x1b] = 0;
if ((param_2 & 1) != 0) {
operator_delete(param_1);
}
return param_1;
}
// --- FUN_005085b0 at 0x005085B0 (size: 64) ---
undefined4 * __thiscall FUN_005085b0(undefined4 *param_1,byte param_2)
{
*param_1 = &PTR_FUN_007c744c;
if ((undefined4 *)param_1[0x18] != param_1 + 1) {
operator_delete__((undefined4 *)param_1[0x18]);
}
param_1[0x18] = 0;
param_1[0x19] = 0;
param_1[0x1a] = 0;
param_1[0x1b] = 0;
if ((param_2 & 1) != 0) {
operator_delete(param_1);
}
return param_1;
}
// --- FUN_005085f0 at 0x005085F0 (size: 92) ---
int __thiscall FUN_005085f0(int param_1,uint param_2)
{
int *piVar1;
int iVar2;
int iVar3;
int iVar4;
piVar1 = (int *)(*(int *)(param_1 + 0xc) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 8) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 4)) * 4);
iVar2 = *piVar1;
if (iVar2 != 0) {
if (*(uint *)(iVar2 + 8) == param_2) {
*piVar1 = *(int *)(iVar2 + 4);
return iVar2;
}
iVar3 = *(int *)(iVar2 + 4);
while (iVar3 != 0) {
iVar4 = *(int *)(iVar2 + 4);
if (*(uint *)(iVar4 + 8) == param_2) {
iVar3 = *(int *)(iVar2 + 4);
*(undefined4 *)(iVar2 + 4) = *(undefined4 *)(iVar3 + 4);
return iVar3;
}
iVar2 = iVar4;
iVar3 = *(int *)(iVar4 + 4);
}
}
return 0;
}
// --- FUN_00508650 at 0x00508650 (size: 142) ---
void __thiscall FUN_00508650(int *param_1,undefined4 *param_2,int *param_3)
{
int iVar1;
int *piVar2;
int *piVar3;
int *unaff_EBP;
int *local_4;
local_4 = param_1;
if (param_3 == (int *)0x0) {
piVar3 = (int *)*param_1;
if (piVar3 != (int *)0x0) {
*param_1 = 0;
(**(code **)(*piVar3 + 0x14))();
param_1[1] = 0;
}
*param_2 = 0x80004002;
return;
}
iVar1 = *param_3;
param_3 = (int *)0x0;
piVar3 = (int *)(**(code **)(iVar1 + 0xc))(&local_4,&DAT_007c7430,&param_3);
piVar2 = local_4;
iVar1 = *piVar3;
piVar3 = (int *)*param_1;
if (iVar1 < 0) {
if (piVar3 != (int *)0x0) {
(**(code **)(*piVar3 + 0x14))();
}
*param_1 = 0;
param_1[1] = 0;
*unaff_EBP = iVar1;
return;
}
if (piVar3 != (int *)0x0) {
(**(code **)(*piVar3 + 0x14))();
}
*param_1 = (int)piVar2;
param_1[1] = 0;
*unaff_EBP = iVar1;
return;
}
// --- FUN_005086e0 at 0x005086E0 (size: 217) ---
void FUN_005086e0(int param_1)
{
int iVar1;
uint uVar2;
uint uVar3;
uVar3 = 0;
if ((DAT_00842b88 & 1) == 0) {
DAT_00842b88 = DAT_00842b88 | 1;
DAT_00842b78 = 0;
DAT_00842b84 = 0;
DAT_00842b80 = 0;
DAT_00842b7c = 0x80;
_atexit((_func_4879 *)&LAB_007677d0);
}
uVar2 = 0;
if (*(int *)(param_1 + 0x9c) != 0) {
do {
iVar1 = *(int *)(*(int *)(param_1 + 0xa0) + uVar2 * 4);
if (((*(byte *)(iVar1 + 0xa8) & 1) == 0) && (*(int *)(iVar1 + 0x40) == 0)) {
if (DAT_00842b84 <= uVar3) {
FUN_00508200(DAT_00842b7c + uVar3);
}
*(int *)(DAT_00842b78 + uVar3 * 4) = iVar1;
if (DAT_00842b80 <= uVar3) {
DAT_00842b80 = uVar3 + 1;
}
uVar3 = uVar3 + 1;
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x9c));
}
uVar2 = 0;
if (uVar3 != 0) {
do {
FUN_00514d20();
uVar2 = uVar2 + 1;
} while (uVar2 < uVar3);
}
return;
}
// --- FUN_005087c0 at 0x005087C0 (size: 80) ---
void __fastcall FUN_005087c0(undefined4 param_1)
{
int *piVar1;
undefined1 *puVar2;
undefined *puVar3;
int *piVar4;
undefined4 uVar5;
undefined1 local_c [4];
int *local_8;
undefined4 local_4;
local_8 = (int *)0x0;
local_4 = 0;
FUN_00508650(local_c,param_1);
piVar1 = local_8;
uVar5 = 0;
puVar2 = local_c;
puVar3 = &DAT_007c7378;
piVar4 = local_8;
FUN_00406d10(puVar2,&DAT_007c7378,local_8,0);
FUN_00406c90(puVar2,puVar3,piVar4,uVar5);
if (piVar1 != (int *)0x0) {
(**(code **)(*piVar1 + 0x14))();
}
return;
}
// --- FUN_00508810 at 0x00508810 (size: 57) ---
void __thiscall FUN_00508810(int param_1,int param_2)
{
uint uVar1;
uVar1 = (*(uint *)(param_2 + 8) >> ((byte)*(undefined4 *)(param_1 + 0x8c) & 0x1f) ^
*(uint *)(param_2 + 8)) & *(uint *)(param_1 + 0x88);
*(undefined4 *)(param_2 + 4) = *(undefined4 *)(*(int *)(param_1 + 0x90) + uVar1 * 4);
*(int *)(*(int *)(param_1 + 0x90) + uVar1 * 4) = param_2;
return;
}
// --- FUN_00508850 at 0x00508850 (size: 57) ---
void __thiscall FUN_00508850(int param_1,int param_2)
{
uint uVar1;
uVar1 = (*(uint *)(param_2 + 8) >> ((byte)*(undefined4 *)(param_1 + 0xbc) & 0x1f) ^
*(uint *)(param_2 + 8)) & *(uint *)(param_1 + 0xb8);
*(undefined4 *)(param_2 + 4) = *(undefined4 *)(*(int *)(param_1 + 0xc0) + uVar1 * 4);
*(int *)(*(int *)(param_1 + 0xc0) + uVar1 * 4) = param_2;
return;
}
// --- FUN_00508890 at 0x00508890 (size: 65) ---
int __thiscall FUN_00508890(int param_1,uint param_2)
{
int iVar1;
iVar1 = *(int *)(*(int *)(param_1 + 0x90) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 0x8c) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 0x88)) * 4);
while( true ) {
if (iVar1 == 0) {
return 0;
}
if (param_2 == *(uint *)(iVar1 + 8)) break;
iVar1 = *(int *)(iVar1 + 4);
}
return iVar1;
}
// --- FUN_005088e0 at 0x005088E0 (size: 65) ---
int __thiscall FUN_005088e0(int param_1,uint param_2)
{
int iVar1;
iVar1 = *(int *)(*(int *)(param_1 + 0xc0) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 0xbc) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 0xb8)) * 4);
while( true ) {
if (iVar1 == 0) {
return 0;
}
if (param_2 == *(uint *)(iVar1 + 8)) break;
iVar1 = *(int *)(iVar1 + 4);
}
return iVar1;
}
// --- FUN_00508930 at 0x00508930 (size: 65) ---
int __thiscall FUN_00508930(int param_1,uint param_2)
{
int iVar1;
iVar1 = *(int *)(*(int *)(param_1 + 0x1d8) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 0x1d4) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 0x1d0)) * 4);
while( true ) {
if (iVar1 == 0) {
return 0;
}
if (param_2 == *(uint *)(iVar1 + 8)) break;
iVar1 = *(int *)(iVar1 + 4);
}
return iVar1;
}
// --- FUN_00508980 at 0x00508980 (size: 133) ---
void __thiscall FUN_00508980(int param_1,undefined4 param_2)
{
int iVar1;
uint uVar2;
if (param_1 == -0xb4) {
return;
}
iVar1 = **(int **)(param_1 + 0xc0);
if (iVar1 == 0) {
FUN_004d8d00();
}
uVar2 = 0;
do {
do {
(**(code **)(*(int *)(iVar1 + 0xc) + 0xc))(param_2);
iVar1 = *(int *)(iVar1 + 4);
} while (iVar1 != 0);
do {
uVar2 = uVar2 + 1;
if (*(uint *)(param_1 + 0xc4) <= uVar2) {
return;
}
iVar1 = *(int *)(*(int *)(param_1 + 0xc0) + uVar2 * 4);
} while (iVar1 == 0);
} while( true );
}
// --- FUN_00508a10 at 0x00508A10 (size: 47) ---
void __thiscall FUN_00508a10(int param_1,uint *param_2)
{
uint *puVar1;
for (puVar1 = *(uint **)(*(int *)(param_1 + 0x60) + (*param_2 % *(uint *)(param_1 + 0x68)) * 4);
(puVar1 != (uint *)0x0 && (*puVar1 != *param_2)); puVar1 = (uint *)puVar1[1]) {
}
return;
}
// --- FUN_00508a40 at 0x00508A40 (size: 58) ---
undefined4 FUN_00508a40(undefined4 param_1,int *param_2,int *param_3)
{
int iVar1;
iVar1 = FUN_00508890(param_1);
*param_2 = iVar1;
iVar1 = FUN_005088e0(param_1);
*param_3 = iVar1;
if ((*param_2 == 0) && (iVar1 == 0)) {
return 0;
}
return 1;
}
// --- FUN_00508a80 at 0x00508A80 (size: 58) ---
void FUN_00508a80(int param_1)
{
int iVar1;
int iVar2;
iVar1 = param_1;
if ((*(int *)(param_1 + 0x90) == 0) && (*(int *)(param_1 + 0x40) == 0)) {
param_1 = *(undefined4 *)(param_1 + 0x4c);
iVar2 = FUN_00508a10(&param_1);
if (iVar2 != 0) {
FUN_00508420(iVar1);
}
}
return;
}
// --- FUN_00508ac0 at 0x00508AC0 (size: 143) ---
undefined4 * __thiscall FUN_00508ac0(undefined4 *param_1,undefined4 param_2)
{
undefined *puVar1;
uint *puVar2;
undefined4 uVar3;
uint uVar4;
int iVar5;
undefined4 *puVar6;
param_1[0x18] = 0;
param_1[0x19] = 0;
param_1[0x1a] = 0;
param_1[0x1b] = 0;
*param_1 = &PTR_FUN_007c7448;
puVar1 = PTR_DAT_00818558;
puVar2 = (uint *)FUN_00422d20(PTR_DAT_00818554,PTR_DAT_00818558,&param_2,param_2,0);
if (puVar2 == (uint *)puVar1) {
puVar2 = puVar2 + -1;
}
uVar4 = *puVar2;
param_1[0x1a] = uVar4;
if (uVar4 < 0x18) {
param_1[0x18] = param_1 + 1;
}
else {
uVar3 = thunk_FUN_005df0f5(uVar4 << 2);
param_1[0x18] = uVar3;
}
param_1[0x19] = (undefined4 *)param_1[0x18] + param_1[0x1a];
puVar6 = (undefined4 *)param_1[0x18];
for (uVar4 = param_1[0x1a] & 0x3fffffff; uVar4 != 0; uVar4 = uVar4 - 1) {
*puVar6 = 0;
puVar6 = puVar6 + 1;
}
for (iVar5 = 0; iVar5 != 0; iVar5 = iVar5 + -1) {
*(undefined1 *)puVar6 = 0;
puVar6 = (undefined4 *)((int)puVar6 + 1);
}
return param_1;
}
// --- FUN_00508b50 at 0x00508B50 (size: 143) ---
undefined4 * __thiscall FUN_00508b50(undefined4 *param_1,undefined4 param_2)
{
undefined *puVar1;
uint *puVar2;
undefined4 uVar3;
uint uVar4;
int iVar5;
undefined4 *puVar6;
param_1[0x18] = 0;
param_1[0x19] = 0;
param_1[0x1a] = 0;
param_1[0x1b] = 0;
*param_1 = &PTR_FUN_007c744c;
puVar1 = PTR_DAT_00818558;
puVar2 = (uint *)FUN_00422d20(PTR_DAT_00818554,PTR_DAT_00818558,&param_2,param_2,0);
if (puVar2 == (uint *)puVar1) {
puVar2 = puVar2 + -1;
}
uVar4 = *puVar2;
param_1[0x1a] = uVar4;
if (uVar4 < 0x18) {
param_1[0x18] = param_1 + 1;
}
else {
uVar3 = thunk_FUN_005df0f5(uVar4 << 2);
param_1[0x18] = uVar3;
}
param_1[0x19] = (undefined4 *)param_1[0x18] + param_1[0x1a];
puVar6 = (undefined4 *)param_1[0x18];
for (uVar4 = param_1[0x1a] & 0x3fffffff; uVar4 != 0; uVar4 = uVar4 - 1) {
*puVar6 = 0;
puVar6 = puVar6 + 1;
}
for (iVar5 = 0; iVar5 != 0; iVar5 = iVar5 + -1) {
*(undefined1 *)puVar6 = 0;
puVar6 = (undefined4 *)((int)puVar6 + 1);
}
return param_1;
}
// --- FUN_00508be0 at 0x00508BE0 (size: 141) ---
void __fastcall FUN_00508be0(int param_1)
{
int iVar1;
void *pvVar2;
void *pvVar3;
int *piVar4;
void *pvVar5;
iVar1 = *(int *)(param_1 + 0x6c);
do {
if (iVar1 == 0) {
return;
}
piVar4 = *(int **)(param_1 + 100);
while (piVar4 != (int *)(*(int *)(param_1 + 0x60) + *(int *)(param_1 + 0x68) * 4)) {
if (**(int **)(param_1 + 100) != 0) {
piVar4 = *(int **)(param_1 + 100);
pvVar5 = (void *)*piVar4;
goto LAB_00508c1f;
}
piVar4 = *(int **)(param_1 + 100) + 1;
*(int **)(param_1 + 100) = piVar4;
}
piVar4 = (int *)0x0;
pvVar5 = (void *)0x0;
LAB_00508c1f:
pvVar3 = (void *)*piVar4;
if (pvVar3 == pvVar5) {
LAB_00508c32:
*piVar4 = *(int *)((int)pvVar3 + 4);
}
else {
do {
pvVar2 = pvVar3;
pvVar3 = *(void **)((int)pvVar2 + 4);
} while (pvVar3 != pvVar5);
if (pvVar2 == (void *)0x0) goto LAB_00508c32;
*(undefined4 *)((int)pvVar2 + 4) = *(undefined4 *)((int)pvVar3 + 4);
}
*(int *)(param_1 + 0x6c) = *(int *)(param_1 + 0x6c) + -1;
if (pvVar5 != (void *)0x0) {
operator_delete__(*(void **)((int)pvVar5 + 0xc));
*(undefined4 *)((int)pvVar5 + 0xc) = 0;
operator_delete(pvVar5);
}
iVar1 = *(int *)(param_1 + 0x6c);
} while( true );
}
// --- FUN_00508c70 at 0x00508C70 (size: 105) ---
uint * __thiscall FUN_00508c70(int param_1,uint param_2)
{
uint *puVar1;
uint *puVar2;
puVar2 = *(uint **)(*(int *)(param_1 + 0x74) + (param_2 % *(uint *)(param_1 + 0x7c)) * 4);
do {
if (puVar2 == (uint *)0x0) {
LAB_00508ca1:
puVar1 = (uint *)FUN_005df0f5(0x1c);
puVar2 = (uint *)0x0;
if (puVar1 != (uint *)0x0) {
puVar1[1] = 0;
puVar1[2] = 0;
*puVar1 = param_2;
puVar1[3] = 0;
puVar1[6] = 0;
puVar1[5] = 0;
puVar1[4] = 0x80;
puVar2 = puVar1;
}
FUN_0042bd40(puVar2);
return puVar2;
}
if (*puVar2 == param_2) {
if (puVar2 != (uint *)0x0) {
return puVar2;
}
goto LAB_00508ca1;
}
puVar2 = (uint *)puVar2[1];
} while( true );
}
// --- FUN_00508ce0 at 0x00508CE0 (size: 80) ---
void FUN_00508ce0(int param_1,undefined4 param_2)
{
int iVar1;
int iVar2;
if (*(int *)(param_1 + 0x40) == 0) {
FUN_0050ffc0(param_2);
iVar2 = FUN_00508c70(*(undefined4 *)(param_1 + 0x4c));
if (*(uint *)(iVar2 + 0x18) <= *(uint *)(iVar2 + 8)) {
FUN_00508200(*(uint *)(iVar2 + 8) + 5);
}
iVar1 = *(int *)(iVar2 + 8);
*(int *)(iVar2 + 8) = iVar1 + 1;
*(int *)(*(int *)(iVar2 + 0xc) + iVar1 * 4) = param_1;
}
return;
}
// --- FUN_00508d30 at 0x00508D30 (size: 104) ---
void FUN_00508d30(int param_1)
{
void *pvVar1;
uint uVar2;
param_1 = *(undefined4 *)(param_1 + 0x28);
pvVar1 = (void *)FUN_004171e0(&param_1);
if (pvVar1 != (void *)0x0) {
uVar2 = 0;
if (*(int *)((int)pvVar1 + 8) != 0) {
do {
FUN_00516d50();
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)((int)pvVar1 + 8));
}
*(undefined4 *)((int)pvVar1 + 8) = 0;
operator_delete__(*(void **)((int)pvVar1 + 0xc));
*(undefined4 *)((int)pvVar1 + 0xc) = 0;
operator_delete(pvVar1);
}
return;
}
// --- FUN_00508da0 at 0x00508DA0 (size: 94) ---
undefined4 FUN_00508da0(undefined4 *param_1,undefined4 *param_2)
{
char cVar1;
undefined4 *puVar2;
puVar2 = (undefined4 *)FUN_005df0f5(0x10);
if (puVar2 == (undefined4 *)0x0) {
puVar2 = (undefined4 *)0x0;
}
else {
*puVar2 = *param_1;
puVar2[1] = 0;
puVar2[2] = *param_2;
puVar2[3] = param_2[1];
}
cVar1 = FUN_0042bd40(puVar2);
if (cVar1 == '\0') {
if (puVar2 != (undefined4 *)0x0) {
operator_delete(puVar2);
}
return 0;
}
return 1;
}
// --- FUN_00508e00 at 0x00508E00 (size: 82) ---
undefined4 * __thiscall FUN_00508e00(undefined4 *param_1,byte param_2)
{
*param_1 = &PTR_FUN_007c7454;
FUN_005870f0();
param_1[1] = &PTR_FUN_007c744c;
if ((undefined4 *)param_1[0x19] != param_1 + 2) {
operator_delete__((undefined4 *)param_1[0x19]);
}
param_1[0x19] = 0;
param_1[0x1a] = 0;
param_1[0x1b] = 0;
param_1[0x1c] = 0;
if ((param_2 & 1) != 0) {
operator_delete(param_1);
}
return param_1;
}
// --- FUN_00508e60 at 0x00508E60 (size: 175) ---
void __fastcall FUN_00508e60(int param_1)
{
int iVar1;
uint uVar2;
FUN_005870f0();
uVar2 = 0;
if (param_1 == -0x84) {
return;
}
iVar1 = **(int **)(param_1 + 0x90);
if (iVar1 == 0) {
FUN_004d8d00();
uVar2 = 0;
}
do {
do {
if ((*(int *)(iVar1 + 0x90) != 0) && ((*(byte *)(iVar1 + 0xa8) & 1) == 0)) {
FUN_0045ce60(iVar1 + 8);
}
iVar1 = *(int *)(iVar1 + 4);
} while (iVar1 != 0);
do {
uVar2 = uVar2 + 1;
if (*(uint *)(param_1 + 0x94) <= uVar2) {
return;
}
iVar1 = *(int *)(*(int *)(param_1 + 0x90) + uVar2 * 4);
} while (iVar1 == 0);
} while( true );
}
// --- FUN_00508f10 at 0x00508F10 (size: 30) ---
void FUN_00508f10(void)
{
void *pvVar1;
pvVar1 = (void *)FUN_004171e0(&stack0x00000004);
if (pvVar1 != (void *)0x0) {
operator_delete(pvVar1);
}
return;
}
// --- FUN_00508f30 at 0x00508F30 (size: 108) ---
void FUN_00508f30(undefined4 *param_1)
{
void *pvVar1;
FUN_00515960();
FUN_005160a0();
FUN_005085f0(param_1[2]);
FUN_005085f0(param_1[2]);
pvVar1 = (void *)FUN_004171e0(param_1 + 2);
if (pvVar1 != (void *)0x0) {
operator_delete(pvVar1);
}
FUN_00513f70();
FUN_00513fe0();
(**(code **)*param_1)(1);
return;
}
// --- FUN_00508fa0 at 0x00508FA0 (size: 255) ---
undefined4 __thiscall FUN_00508fa0(int param_1,uint param_2)
{
int *piVar1;
int iVar2;
undefined4 unaff_EBX;
for (iVar2 = *(int *)(*(int *)(param_1 + 0x90) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 0x8c) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 0x88)) * 4); iVar2 != 0; iVar2 = *(int *)(iVar2 + 4)) {
if (param_2 == *(uint *)(iVar2 + 8)) goto LAB_00508fe2;
}
iVar2 = 0;
LAB_00508fe2:
if (iVar2 == 0) {
for (iVar2 = *(int *)(*(int *)(param_1 + 0xa8) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 0xa4) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 0xa0)) * 4); iVar2 != 0; iVar2 = *(int *)(iVar2 + 4)) {
if (param_2 == *(uint *)(iVar2 + 8)) goto LAB_00509015;
}
iVar2 = 0;
LAB_00509015:
if (iVar2 == 0) goto LAB_0050902b;
}
FUN_00508f30(iVar2);
LAB_0050902b:
piVar1 = *(int **)(*(int *)(param_1 + 0xc0) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 0xbc) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 0xb8)) * 4);
while( true ) {
if (piVar1 == (int *)0x0) {
return 0;
}
if (param_2 == piVar1[2]) break;
piVar1 = (int *)piVar1[1];
}
if (piVar1 == (int *)0x0) {
return 0;
}
(**(code **)(*piVar1 + 4))();
FUN_005085f0(piVar1[2]);
FUN_005085f0(piVar1[2]);
(**(code **)*piVar1)(1);
return unaff_EBX;
}
// --- FUN_00509420 at 0x00509420 (size: 3) ---
void FUN_00509420(void)
{
return;
}
// --- FUN_00509430 at 0x00509430 (size: 3) ---
undefined4 FUN_00509430(void)
{
return 0;
}
// --- FUN_00509450 at 0x00509450 (size: 36) ---
int __fastcall FUN_00509450(int *param_1)
{
int iVar1;
iVar1 = FUN_00401ea0();
if ((iVar1 == 0) && (param_1 != (int *)0x0)) {
(**(code **)(*param_1 + 0x20))(1);
}
return iVar1;
}
// --- FUN_00509480 at 0x00509480 (size: 627) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __fastcall FUN_00509480(int *param_1)
{
uint *puVar1;
undefined4 uVar2;
void *pvVar3;
int *piVar4;
int iVar5;
uint uVar6;
uint local_34;
int *local_30;
uint local_2c;
double local_28;
int *local_1c;
uint local_18;
int local_14;
undefined4 local_10;
int local_c;
if (param_1[4] == 0) {
return;
}
local_30 = param_1;
if (_DAT_007c7420 < (double)CONCAT44(DAT_008379ac,DAT_008379a8) - _DAT_00842b90) {
FUN_00508e60();
_DAT_00842b90 = DAT_008379a8;
_DAT_00842b94 = DAT_008379ac;
}
local_34 = 0;
do {
if (((param_1[0x7b] < 1) || ((double *)param_1[0x7a] == (double *)0x0)) ||
(local_28 = *(double *)param_1[0x7a], (double)CONCAT44(DAT_008379ac,DAT_008379a8) <= local_28
)) {
local_1c = param_1 + 0x27;
local_10 = 0;
local_18 = 0;
if (local_1c != (int *)0x0) {
local_14 = *(int *)param_1[0x2a];
local_c = 0;
piVar4 = local_1c;
iVar5 = local_14;
uVar6 = 0;
if ((local_14 != 0) ||
(FUN_004d8d00(), piVar4 = local_1c, param_1 = local_30, iVar5 = local_14,
uVar6 = local_18, local_c == 0)) {
do {
do {
uVar2 = DAT_008379ac;
if (_DAT_007c7428 <
(double)CONCAT44(DAT_008379ac,DAT_008379a8) - *(double *)(iVar5 + 0xd8)) {
*(undefined4 *)(iVar5 + 0xd8) = DAT_008379a8;
*(undefined4 *)(iVar5 + 0xdc) = uVar2;
FUN_00547590(*(undefined4 *)(iVar5 + 8));
}
iVar5 = *(int *)(iVar5 + 4);
} while (iVar5 != 0);
do {
uVar6 = uVar6 + 1;
param_1 = local_30;
if ((uint)piVar4[4] <= uVar6) goto LAB_0050964d;
iVar5 = *(int *)(piVar4[3] + uVar6 * 4);
} while (iVar5 == 0);
} while( true );
}
}
LAB_0050964d:
local_1c = param_1 + 0x33;
local_10 = 0;
local_18 = 0;
if (local_1c == (int *)0x0) {
return;
}
local_14 = *(int *)param_1[0x36];
local_c = 0;
piVar4 = local_1c;
iVar5 = local_14;
uVar6 = 0;
if ((local_14 == 0) &&
(FUN_004d8d00(), piVar4 = local_1c, iVar5 = local_14, uVar6 = local_18, local_c != 0)) {
return;
}
do {
do {
uVar2 = DAT_008379ac;
if (_DAT_007c7428 <
(double)CONCAT44(DAT_008379ac,DAT_008379a8) - *(double *)(iVar5 + 0x18)) {
*(undefined4 *)(iVar5 + 0x18) = DAT_008379a8;
*(undefined4 *)(iVar5 + 0x1c) = uVar2;
FUN_00547590(*(undefined4 *)(iVar5 + 8));
}
iVar5 = *(int *)(iVar5 + 4);
} while (iVar5 != 0);
do {
uVar6 = uVar6 + 1;
if ((uint)piVar4[4] <= uVar6) {
return;
}
iVar5 = *(int *)(piVar4[3] + uVar6 * 4);
} while (iVar5 == 0);
} while( true );
}
FUN_005084f0(&local_28,&local_34);
uVar6 = local_34;
local_2c = local_34;
for (puVar1 = *(uint **)(param_1[0x6f] + (local_34 % (uint)param_1[0x71]) * 4);
puVar1 != (uint *)0x0; puVar1 = (uint *)puVar1[1]) {
if (*puVar1 == local_34) {
if ((puVar1 != (uint *)0x0) &&
(ABS(*(double *)(puVar1 + 2) - local_28) < (double)_DAT_007c7440)) {
pvVar3 = (void *)FUN_004171e0(&local_2c);
if (pvVar3 != (void *)0x0) {
operator_delete(pvVar3);
}
(**(code **)(*param_1 + 0x1c))(uVar6);
}
break;
}
}
} while( true );
}
// --- FUN_00509700 at 0x00509700 (size: 829) ---
void __fastcall FUN_00509700(int param_1)
{
int *piVar1;
undefined4 *puVar2;
int iVar3;
uint *puVar4;
int iVar5;
int iVar6;
bool bVar7;
uint *puVar8;
uint *puVar9;
uint uVar10;
undefined4 *puVar11;
uint local_10;
undefined4 *local_c;
local_10 = 0;
if (param_1 != -0x84) {
local_c = (undefined4 *)**(int **)(param_1 + 0x90);
bVar7 = false;
if (local_c != (undefined4 *)0x0) goto LAB_0050975b;
FUN_004d8d00();
LAB_0050974b:
puVar11 = local_c;
if (local_c == (undefined4 *)0x0) {
LAB_00509766:
do {
local_10 = local_10 + 1;
if (*(uint *)(param_1 + 0x94) <= local_10) {
bVar7 = true;
break;
}
local_c = *(undefined4 **)(*(int *)(param_1 + 0x90) + local_10 * 4);
} while (local_c == (undefined4 *)0x0);
}
else {
LAB_0050975b:
puVar2 = (undefined4 *)local_c[1];
puVar11 = local_c;
local_c = puVar2;
if (puVar2 == (undefined4 *)0x0) goto LAB_00509766;
}
FUN_00515960();
FUN_005160a0();
uVar10 = puVar11[2];
piVar1 = (int *)(*(int *)(param_1 + 0x90) +
((uVar10 >> ((byte)*(undefined4 *)(param_1 + 0x8c) & 0x1f) ^ uVar10) &
*(uint *)(param_1 + 0x88)) * 4);
iVar3 = *piVar1;
if (iVar3 != 0) {
if (*(uint *)(iVar3 + 8) == uVar10) {
*piVar1 = *(int *)(iVar3 + 4);
}
else {
iVar5 = *(int *)(iVar3 + 4);
while (iVar5 != 0) {
iVar6 = *(int *)(iVar3 + 4);
if (*(uint *)(iVar6 + 8) == uVar10) {
*(undefined4 *)(iVar3 + 4) = *(undefined4 *)(*(int *)(iVar3 + 4) + 4);
break;
}
iVar3 = iVar6;
iVar5 = *(int *)(iVar6 + 4);
}
}
}
uVar10 = puVar11[2];
piVar1 = (int *)(*(int *)(param_1 + 0xa8) +
((uVar10 >> ((byte)*(undefined4 *)(param_1 + 0xa4) & 0x1f) ^ uVar10) &
*(uint *)(param_1 + 0xa0)) * 4);
iVar3 = *piVar1;
if (iVar3 != 0) {
if (*(uint *)(iVar3 + 8) == uVar10) {
*piVar1 = *(int *)(iVar3 + 4);
}
else {
iVar5 = *(int *)(iVar3 + 4);
while (iVar5 != 0) {
iVar6 = *(int *)(iVar3 + 4);
if (*(uint *)(iVar6 + 8) == uVar10) {
*(undefined4 *)(iVar3 + 4) = *(undefined4 *)(*(int *)(iVar3 + 4) + 4);
break;
}
iVar3 = iVar6;
iVar5 = *(int *)(iVar6 + 4);
}
}
}
uVar10 = (uint)puVar11[2] % *(uint *)(param_1 + 0x1c4);
puVar9 = *(uint **)(*(int *)(param_1 + 0x1bc) + uVar10 * 4);
for (puVar4 = puVar9; puVar4 != (uint *)0x0; puVar4 = (uint *)puVar4[1]) {
if (*puVar4 == puVar11[2]) {
if (puVar4 != (uint *)0x0) {
if (puVar9 != puVar4) goto LAB_00509875;
goto LAB_00509882;
}
break;
}
}
goto LAB_005098a5;
}
LAB_005098c9:
if (param_1 == -0xb4) {
puVar11 = (undefined4 *)0x0;
LAB_0050990b:
if (puVar11 == (undefined4 *)0x0) goto LAB_005099fa;
}
else {
puVar11 = (undefined4 *)**(int **)(param_1 + 0xc0);
if (puVar11 == (undefined4 *)0x0) {
FUN_004d8d00();
goto LAB_0050990b;
}
}
LAB_00509913:
do {
uVar10 = puVar11[2];
piVar1 = (int *)(*(int *)(param_1 + 0xc0) +
((uVar10 >> ((byte)*(undefined4 *)(param_1 + 0xbc) & 0x1f) ^ uVar10) &
*(uint *)(param_1 + 0xb8)) * 4);
iVar3 = *piVar1;
if (iVar3 != 0) {
if (*(uint *)(iVar3 + 8) == uVar10) {
*piVar1 = *(int *)(iVar3 + 4);
}
else {
iVar5 = *(int *)(iVar3 + 4);
while (iVar5 != 0) {
iVar6 = *(int *)(iVar3 + 4);
if (*(uint *)(iVar6 + 8) == uVar10) {
*(undefined4 *)(iVar3 + 4) = *(undefined4 *)(*(int *)(iVar3 + 4) + 4);
break;
}
iVar3 = iVar6;
iVar5 = *(int *)(iVar6 + 4);
}
}
}
uVar10 = puVar11[2];
piVar1 = (int *)(*(int *)(param_1 + 0xd8) +
((uVar10 >> ((byte)*(undefined4 *)(param_1 + 0xd4) & 0x1f) ^ uVar10) &
*(uint *)(param_1 + 0xd0)) * 4);
iVar3 = *piVar1;
if (iVar3 != 0) {
if (*(uint *)(iVar3 + 8) == uVar10) {
*piVar1 = *(int *)(iVar3 + 4);
}
else {
iVar5 = *(int *)(iVar3 + 4);
while (iVar5 != 0) {
iVar6 = *(int *)(iVar3 + 4);
if (*(uint *)(iVar6 + 8) == uVar10) {
*(undefined4 *)(iVar3 + 4) = *(undefined4 *)(*(int *)(iVar3 + 4) + 4);
break;
}
iVar3 = iVar6;
iVar5 = *(int *)(iVar6 + 4);
}
}
}
(**(code **)*puVar11)(1);
if (param_1 == -0xb4) {
puVar11 = (undefined4 *)0x0;
}
else {
puVar11 = (undefined4 *)**(undefined4 **)(param_1 + 0xc0);
if (puVar11 != (undefined4 *)0x0) goto LAB_00509913;
FUN_004d8d00();
}
} while (puVar11 != (undefined4 *)0x0);
LAB_005099fa:
FUN_00524910();
FUN_00524910();
FUN_00524910();
FUN_00524910();
FUN_00508be0();
FUN_00524910();
return;
LAB_00509875:
do {
puVar8 = puVar9;
puVar9 = (uint *)puVar8[1];
} while (puVar9 != puVar4);
if (puVar8 == (uint *)0x0) {
LAB_00509882:
*(uint *)(*(int *)(param_1 + 0x1bc) + uVar10 * 4) = puVar9[1];
}
else {
puVar8[1] = puVar9[1];
}
*(int *)(param_1 + 0x1c8) = *(int *)(param_1 + 0x1c8) + -1;
operator_delete(puVar4);
LAB_005098a5:
FUN_00513f70();
FUN_00513fe0();
(**(code **)*puVar11)(1);
if (bVar7) goto LAB_005098c9;
goto LAB_0050974b;
}
// --- FUN_00509a40 at 0x00509A40 (size: 111) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void FUN_00509a40(undefined4 param_1)
{
undefined4 uVar1;
void *pvVar2;
undefined8 local_8;
uVar1 = param_1;
local_8 = (double)CONCAT44(local_8._4_4_,param_1);
pvVar2 = (void *)FUN_004171e0(&local_8);
if (pvVar2 != (void *)0x0) {
operator_delete(pvVar2);
}
local_8 = _DAT_008379a8 + _DAT_007c7418;
FUN_00508da0(&param_1,&local_8);
FUN_00508470((undefined4)local_8,local_8._4_4_,uVar1);
return;
}
// --- FUN_00509ab0 at 0x00509AB0 (size: 171) ---
int __thiscall FUN_00509ab0(int param_1,uint param_2,int param_3)
{
undefined4 uVar1;
int iVar2;
uint uVar3;
for (iVar2 = *(int *)(*(int *)(param_1 + 0xa8) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 0xa4) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 0xa0)) * 4); iVar2 != 0; iVar2 = *(int *)(iVar2 + 4)) {
if (param_2 == *(uint *)(iVar2 + 8)) goto LAB_00509aee;
}
iVar2 = 0;
LAB_00509aee:
if ((iVar2 == 0) && (param_3 != 0)) {
iVar2 = FUN_00513100(param_2,1);
uVar1 = DAT_008379a8;
*(undefined4 *)(iVar2 + 0xdc) = DAT_008379ac;
*(undefined4 *)(iVar2 + 0xd8) = uVar1;
uVar3 = (*(uint *)(iVar2 + 8) >> ((byte)*(undefined4 *)(param_1 + 0xa4) & 0x1f) ^
*(uint *)(iVar2 + 8)) & *(uint *)(param_1 + 0xa0);
*(undefined4 *)(iVar2 + 4) = *(undefined4 *)(*(int *)(param_1 + 0xa8) + uVar3 * 4);
*(int *)(*(int *)(param_1 + 0xa8) + uVar3 * 4) = iVar2;
FUN_00509a40(param_2);
}
return iVar2;
}
// --- FUN_00509b60 at 0x00509B60 (size: 163) ---
int __thiscall FUN_00509b60(int param_1,uint param_2,int param_3)
{
undefined4 uVar1;
int iVar2;
uint uVar3;
for (iVar2 = *(int *)(*(int *)(param_1 + 0xd8) +
((param_2 >> ((byte)*(undefined4 *)(param_1 + 0xd4) & 0x1f) ^ param_2) &
*(uint *)(param_1 + 0xd0)) * 4); iVar2 != 0; iVar2 = *(int *)(iVar2 + 4)) {
if (param_2 == *(uint *)(iVar2 + 8)) goto LAB_00509b9e;
}
iVar2 = 0;
LAB_00509b9e:
if ((iVar2 == 0) && (param_3 != 0)) {
iVar2 = FUN_0054bb30(param_2);
uVar1 = DAT_008379a8;
*(undefined4 *)(iVar2 + 0x1c) = DAT_008379ac;
*(undefined4 *)(iVar2 + 0x18) = uVar1;
uVar3 = (*(uint *)(iVar2 + 8) >> ((byte)*(undefined4 *)(param_1 + 0xd4) & 0x1f) ^
*(uint *)(iVar2 + 8)) & *(uint *)(param_1 + 0xd0);
*(undefined4 *)(iVar2 + 4) = *(undefined4 *)(*(int *)(param_1 + 0xd8) + uVar3 * 4);
*(int *)(*(int *)(param_1 + 0xd8) + uVar3 * 4) = iVar2;
FUN_00509a40(param_2);
}
return iVar2;
}
// --- FUN_00509c10 at 0x00509C10 (size: 400) ---
void __fastcall FUN_00509c10(undefined4 *param_1)
{
*param_1 = &PTR_LAB_007c7458;
param_1[1] = &PTR_FUN_00801670;
DAT_00842adc = 0;
FUN_00509700();
param_1[0x79] = &PTR_FUN_007c7444;
operator_delete__((void *)param_1[0x7a]);
param_1[0x73] = &PTR_FUN_007c7450;
if (param_1[0x78] == 0) {
operator_delete__((void *)param_1[0x76]);
}
param_1[0x56] = &PTR_FUN_007c7454;
FUN_005870f0();
param_1[0x57] = &PTR_FUN_007c744c;
if ((undefined4 *)param_1[0x6f] != param_1 + 0x58) {
operator_delete__((undefined4 *)param_1[0x6f]);
}
param_1[0x6f] = 0;
param_1[0x70] = 0;
param_1[0x71] = 0;
param_1[0x72] = 0;
param_1[0x39] = &PTR_FUN_0079cdb0;
FUN_005870f0();
param_1[0x3a] = &PTR_FUN_0079cda8;
if ((undefined4 *)param_1[0x52] != param_1 + 0x3b) {
operator_delete__((undefined4 *)param_1[0x52]);
}
param_1[0x52] = 0;
param_1[0x53] = 0;
param_1[0x54] = 0;
param_1[0x55] = 0;
param_1[0x33] = &PTR_FUN_007c7450;
if (param_1[0x38] == 0) {
operator_delete__((void *)param_1[0x36]);
}
param_1[0x2d] = &PTR_FUN_007c7450;
if (param_1[0x32] == 0) {
operator_delete__((void *)param_1[0x30]);
}
param_1[0x27] = &PTR_FUN_007c7450;
if (param_1[0x2c] == 0) {
operator_delete__((void *)param_1[0x2a]);
}
param_1[0x21] = &PTR_FUN_007c7450;
if (param_1[0x26] == 0) {
operator_delete__((void *)param_1[0x24]);
}
param_1[5] = &PTR_FUN_007c7448;
if ((undefined4 *)param_1[0x1d] != param_1 + 6) {
operator_delete__((undefined4 *)param_1[0x1d]);
}
param_1[0x1d] = 0;
param_1[0x1e] = 0;
param_1[0x1f] = 0;
param_1[0x20] = 0;
param_1[2] = &PTR_LAB_00793b6c;
FUN_0043c610();
return;
}
// --- FUN_00509da0 at 0x00509DA0 (size: 59) ---
void FUN_00509da0(undefined4 param_1,undefined4 param_2)
{
int iVar1;
iVar1 = FUN_00508890(param_1);
if (iVar1 == 0) {
FUN_00509ab0(param_1,1);
FUN_00509a40(param_1);
}
FUN_00514270(param_2);
return;
}
// --- FUN_00509de0 at 0x00509DE0 (size: 46) ---
void FUN_00509de0(undefined4 param_1,undefined4 param_2,undefined4 param_3)
{
FUN_00509b60(param_1,1);
FUN_00509f00(param_2,param_3);
FUN_00509a40(param_1);
return;
}
// --- FUN_00509e10 at 0x00509E10 (size: 41) ---
void FUN_00509e10(undefined4 param_1,undefined4 param_2)
{
FUN_00509b60(param_1,1);
FUN_00509f50(param_2);
FUN_00509a40(param_1);
return;
}
// --- FUN_00509e40 at 0x00509E40 (size: 160) ---
void __thiscall FUN_00509e40(int param_1,undefined4 param_2)
{
int iVar1;
uint uVar2;
undefined4 uVar3;
uint uVar4;
undefined4 uVar5;
FUN_00513fe0();
uVar4 = 0;
iVar1 = FUN_0051dfb0();
if (iVar1 != 0) {
do {
uVar2 = FUN_0051dfc0(uVar4);
for (iVar1 = *(int *)(*(int *)(param_1 + 0x90) +
((uVar2 >> ((byte)*(undefined4 *)(param_1 + 0x8c) & 0x1f) ^ uVar2) &
*(uint *)(param_1 + 0x88)) * 4); iVar1 != 0; iVar1 = *(int *)(iVar1 + 4))
{
if (uVar2 == *(uint *)(iVar1 + 8)) goto LAB_00509e9e;
}
iVar1 = 0;
LAB_00509e9e:
if (iVar1 == 0) {
uVar5 = 1;
uVar3 = FUN_0051dfc0(uVar4);
FUN_00509ab0(uVar3,uVar5);
}
uVar3 = FUN_0051dfd0(uVar4);
FUN_00516590(param_2,uVar3);
uVar4 = uVar4 + 1;
uVar2 = FUN_0051dfb0();
} while (uVar4 < uVar2);
}
return;
}
// --- FUN_00509ee0 at 0x00509EE0 (size: 30) ---
void * __thiscall FUN_00509ee0(void *param_1,byte param_2)
{
FUN_00509c10();
if ((param_2 & 1) != 0) {
operator_delete(param_1);
}
return param_1;
}
// --- FUN_00509f00 at 0x00509F00 (size: 36) ---
void FUN_00509f00(undefined4 param_1,undefined4 param_2)
{
undefined4 local_4;
local_4 = 0;
FUN_005b10e0(param_1,param_2,&local_4);
return;
}
// --- FUN_00509f30 at 0x00509F30 (size: 31) ---
void FUN_00509f30(undefined4 param_1,undefined4 param_2,undefined4 param_3)
{
FUN_005b12d0(param_1,param_2,&param_3,param_3);
return;
}
// --- FUN_00509f50 at 0x00509F50 (size: 122) ---
void __thiscall FUN_00509f50(int param_1,int param_2)
{
int *piVar1;
undefined4 *puVar2;
int *piVar3;
if (*(int *)(param_1 + 0x20) == 0) {
puVar2 = (undefined4 *)FUN_005df0f5(8);
if (puVar2 == (undefined4 *)0x0) {
puVar2 = (undefined4 *)0x0;
}
else {
*puVar2 = 0;
puVar2[1] = 0;
}
*(undefined4 **)(param_1 + 0x20) = puVar2;
}
InterlockedIncrement((LONG *)(param_2 + 4));
piVar1 = *(int **)(param_1 + 0x20);
piVar3 = (int *)FUN_005df0f5(8);
if (piVar3 == (int *)0x0) {
piVar3 = (int *)0x0;
}
else {
*piVar3 = param_2;
piVar3[1] = 0;
}
if (piVar1[1] == 0) {
*piVar1 = (int)piVar3;
piVar1[1] = (int)piVar3;
return;
}
*(int **)(piVar1[1] + 4) = piVar3;
piVar1[1] = *(int *)(piVar1[1] + 4);
return;
}
// --- FUN_0050a0b0 at 0x0050A0B0 (size: 132) ---
void __fastcall FUN_0050a0b0(int param_1)
{
int iVar1;
int *piVar2;
undefined4 *puVar3;
void *pvVar4;
LONG LVar5;
undefined4 *puVar6;
if (*(int **)(param_1 + 0x20) != (int *)0x0) {
iVar1 = **(int **)(param_1 + 0x20);
while (iVar1 != 0) {
piVar2 = *(int **)(param_1 + 0x20);
puVar3 = (undefined4 *)*piVar2;
if (puVar3 == (undefined4 *)0x0) {
puVar6 = (undefined4 *)0x0;
}
else {
iVar1 = puVar3[1];
*piVar2 = iVar1;
if (iVar1 == 0) {
piVar2[1] = 0;
}
puVar6 = (undefined4 *)*puVar3;
operator_delete(puVar3);
}
LVar5 = InterlockedDecrement(puVar6 + 1);
if ((LVar5 == 0) && (puVar6 != (undefined4 *)0x0)) {
(**(code **)*puVar6)(1);
}
iVar1 = **(int **)(param_1 + 0x20);
}
pvVar4 = *(void **)(param_1 + 0x20);
if (pvVar4 != (void *)0x0) {
FUN_004c65a0();
operator_delete(pvVar4);
}
*(undefined4 *)(param_1 + 0x20) = 0;
}
FUN_00693960(param_1);
return;
}
// --- FUN_0050a140 at 0x0050A140 (size: 3) ---
undefined4 __fastcall FUN_0050a140(undefined4 param_1)
{
return param_1;
}
// --- FUN_0050a150 at 0x0050A150 (size: 10) ---
void __thiscall FUN_0050a150(int param_1,undefined4 param_2)
{
*(undefined4 *)(param_1 + 8) = param_2;
return;
}
// --- FUN_0050a160 at 0x0050A160 (size: 201) ---
undefined4
FUN_0050a160(int param_1,undefined4 param_2,undefined4 param_3,ushort param_4,ushort param_5,
int param_6)
{
ushort uVar1;
uint uVar2;
int iVar3;
undefined4 uVar4;
bool bVar5;
uVar4 = 0;
iVar3 = 0;
if (*(int **)(param_1 + 300) != (int *)0x0) {
iVar3 = (**(code **)(**(int **)(param_1 + 300) + 0x14))();
}
uVar1 = *(ushort *)(param_1 + 0x166);
uVar2 = (int)((uint)param_4 - (uint)uVar1) >> 0x1f;
if ((int)(((uint)param_4 - (uint)uVar1 ^ uVar2) - uVar2) < 0x8000) {
bVar5 = uVar1 < param_4;
}
else {
bVar5 = param_4 < uVar1;
}
if (bVar5) {
*(ushort *)(param_1 + 0x166) = param_4;
uVar1 = *(ushort *)(param_1 + 0x16e);
uVar2 = (int)((uint)uVar1 - (uint)param_5) >> 0x1f;
if ((int)(((uint)uVar1 - (uint)param_5 ^ uVar2) - uVar2) < 0x8000) {
bVar5 = param_5 < uVar1;
}
else {
bVar5 = uVar1 < param_5;
}
if (bVar5) {
return 0;
}
*(ushort *)(param_1 + 0x16e) = param_5;
if ((param_6 == 0) || (iVar3 == 0)) {
*(int *)(param_1 + 0xcc) = param_6;
FUN_00512b10(&param_2,param_3);
if (iVar3 != 0) {
uVar4 = 1;
}
}
}
return uVar4;
}
// --- FUN_0050a230 at 0x0050A230 (size: 46) ---
void FUN_0050a230(int param_1)
{
int *piVar1;
int *piVar2;
piVar1 = DAT_00842c50 + DAT_00842c58;
piVar2 = DAT_00842c50;
if (DAT_00842c50 < piVar1) {
while (*piVar2 != param_1) {
piVar2 = piVar2 + 1;
if (piVar1 <= piVar2) {
return;
}
}
*piVar2 = piVar1[-1];
DAT_00842c58 = DAT_00842c58 + -1;
}
return;
}
// --- FUN_0050a260 at 0x0050A260 (size: 133) ---
void FUN_0050a260(undefined4 param_1,undefined2 *param_2,undefined4 param_3)
{
undefined1 uVar1;
undefined2 uVar2;
undefined2 uVar3;
uint uVar4;
uint uVar5;
undefined4 *puVar6;
undefined4 *puVar7;
uVar2 = *param_2;
uVar3 = param_2[1];
uVar1 = *(undefined1 *)(param_2 + 2);
puVar6 = (undefined4 *)((int)param_2 + 5);
uVar4 = (uint)puVar6 & 0x80000003;
if ((int)uVar4 < 0) {
uVar4 = (uVar4 - 1 | 0xfffffffc) + 1;
}
if ((uVar4 != 0) && (uVar4 = 4 - uVar4, uVar4 != 0)) {
puVar7 = puVar6;
for (uVar5 = uVar4 >> 2; uVar5 != 0; uVar5 = uVar5 - 1) {
*puVar7 = 0;
puVar7 = puVar7 + 1;
}
for (uVar5 = uVar4 & 3; uVar5 != 0; uVar5 = uVar5 - 1) {
*(undefined1 *)puVar7 = 0;
puVar7 = (undefined4 *)((int)puVar7 + 1);
}
puVar6 = (undefined4 *)((int)puVar6 + uVar4);
}
FUN_0050a160(param_1,puVar6,param_3,uVar2,uVar3,uVar1);
return;
}
// --- FUN_0050a2f0 at 0x0050A2F0 (size: 225) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void FUN_0050a2f0(float param_1)
{
undefined4 *puVar1;
float fVar2;
float fVar3;
int *piVar4;
uint uVar5;
uint uVar6;
undefined4 uVar7;
uVar6 = 0;
uVar5 = DAT_00842c64;
if (DAT_00842c64 != 0) {
do {
puVar1 = *(undefined4 **)(DAT_00842c5c + uVar6 * 4);
if (puVar1 != (undefined4 *)0x0) {
uVar7 = *puVar1;
FUN_00414590(6,uVar7);
piVar4 = (int *)FUN_00416f40(uVar7);
if (piVar4 == (int *)0x0) {
operator_delete(puVar1);
if ((uVar6 < DAT_00842c64) && (DAT_00842c64 = DAT_00842c64 - 1, uVar6 != DAT_00842c64)) {
*(undefined4 *)(DAT_00842c5c + uVar6 * 4) =
*(undefined4 *)(DAT_00842c5c + DAT_00842c64 * 4);
}
uVar6 = uVar6 - 1;
uVar5 = DAT_00842c64;
}
else {
fVar2 = param_1 * (float)puVar1[1];
fVar3 = param_1 * (float)puVar1[2];
if (_DAT_007938b0 <= (float)puVar1[3]) {
fVar2 = fVar2 - _DAT_007938b0;
}
if (_DAT_007938b0 <= (float)puVar1[4]) {
fVar3 = fVar3 - _DAT_007938b0;
}
puVar1[3] = fVar2 + (float)puVar1[3];
puVar1[4] = fVar3 + (float)puVar1[4];
FUN_00534f10(puVar1[3],puVar1[4]);
(**(code **)(*piVar4 + 0x14))();
uVar5 = DAT_00842c64;
}
}
uVar6 = uVar6 + 1;
} while (uVar6 < uVar5);
}
return;
}
// --- FUN_0050a3e0 at 0x0050A3E0 (size: 62) ---
void __fastcall FUN_0050a3e0(int param_1)
{
void *pvVar1;
uint uVar2;
uVar2 = 0;
if (DAT_00842c64 != 0) {
do {
pvVar1 = *(void **)(DAT_00842c5c + uVar2 * 4);
if (pvVar1 != (void *)0x0) {
operator_delete(pvVar1);
}
uVar2 = uVar2 + 1;
} while (uVar2 < DAT_00842c64);
}
operator_delete(*(void **)(param_1 + 0xc));
return;
}
// --- FUN_0050a420 at 0x0050A420 (size: 269) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __fastcall FUN_0050a420(int param_1)
{
int *piVar1;
int iVar2;
int iVar3;
double dVar4;
uint uVar5;
dVar4 = (double)CONCAT44(DAT_008379ac,DAT_008379a8) - _DAT_00842bb0;
if (dVar4 < _DAT_00795610) {
_DAT_00842bb0 = DAT_008379a8;
_DAT_00842bb4 = DAT_008379ac;
return;
}
if (_DAT_00842c08 <= dVar4) {
piVar1 = *(int **)(param_1 + 0xc);
piVar1[3] = 0;
piVar1[1] = 0;
if (*piVar1 == 0) {
piVar1[4] = 1;
piVar1[2] = 0;
}
else {
piVar1[4] = 0;
iVar2 = **(int **)(*piVar1 + 0xc);
piVar1[2] = iVar2;
if (iVar2 == 0) {
FUN_004d8d00();
}
}
iVar2 = *(int *)(param_1 + 0xc);
iVar3 = *(int *)(iVar2 + 0x10);
while (iVar3 == 0) {
iVar2 = *(int *)(iVar2 + 8);
FUN_00516810();
if (iVar2 == *(int *)(param_1 + 8)) {
FUN_00452da0();
}
FUN_004d8d00();
iVar2 = *(int *)(param_1 + 0xc);
iVar3 = *(int *)(iVar2 + 0x10);
}
uVar5 = 0;
_DAT_00842bb0 = DAT_008379a8;
_DAT_00842bb4 = DAT_008379ac;
if (DAT_00842c58 != 0) {
do {
FUN_005148f0();
uVar5 = uVar5 + 1;
} while (uVar5 < DAT_00842c58);
}
FUN_0050a2f0((float)dVar4);
}
return;
}
// --- FUN_0050a530 at 0x0050A530 (size: 134) ---
int * __thiscall FUN_0050a530(int *param_1,int param_2,int param_3)
{
int iVar1;
int *piVar2;
int iVar3;
param_1[2] = 0;
*param_1 = param_2;
param_1[1] = param_3;
piVar2 = (int *)FUN_005df0f5(0x14);
if (piVar2 == (int *)0x0) {
piVar2 = (int *)0x0;
}
else {
iVar1 = *param_1;
iVar3 = iVar1 + 0x84;
*piVar2 = iVar3;
piVar2[3] = 0;
piVar2[1] = 0;
if (iVar3 == 0) {
piVar2[4] = 1;
piVar2[2] = 0;
}
else {
piVar2[4] = 0;
iVar1 = **(int **)(iVar1 + 0x90);
piVar2[2] = iVar1;
if (iVar1 == 0) {
FUN_004d8d00();
}
}
}
param_1[3] = (int)piVar2;
DAT_008eee70 = DAT_008379a8;
DAT_008eee74 = DAT_008379ac;
return param_1;
}
// --- FUN_0050a5c0 at 0x0050A5C0 (size: 110) ---
void FUN_0050a5c0(int param_1)
{
int *piVar1;
int iVar2;
piVar1 = DAT_00842c50;
do {
if (DAT_00842c50 + DAT_00842c58 <= piVar1) {
LAB_0050a5ef:
if (DAT_00842c54 <= DAT_00842c58) {
if (DAT_00842c54 == 0) {
iVar2 = 8;
}
else {
iVar2 = DAT_00842c54 * 2;
}
iVar2 = FUN_00500570(iVar2);
if (iVar2 == 0) {
return;
}
}
DAT_00842c50[DAT_00842c58] = param_1;
DAT_00842c58 = DAT_00842c58 + 1;
return;
}
if (*piVar1 == param_1) {
*piVar1 = (DAT_00842c50 + DAT_00842c58)[-1];
DAT_00842c58 = DAT_00842c58 - 1;
goto LAB_0050a5ef;
}
piVar1 = piVar1 + 1;
} while( true );
}
// --- FUN_0050a630 at 0x0050A630 (size: 239) ---
void FUN_0050a630(int param_1,float param_2,float param_3)
{
void *pvVar1;
int *piVar2;
int iVar3;
uint uVar4;
uVar4 = 0;
if (DAT_00842c64 != 0) {
do {
piVar2 = *(int **)(DAT_00842c5c + uVar4 * 4);
if ((piVar2 != (int *)0x0) && (param_1 == *piVar2)) {
pvVar1 = *(void **)(DAT_00842c5c + uVar4 * 4);
if ((param_2 != DAT_00796344) || (param_3 != DAT_00796344)) {
*(float *)((int)pvVar1 + 4) = param_2;
*(float *)((int)pvVar1 + 8) = param_3;
return;
}
if ((uVar4 < DAT_00842c64) && (DAT_00842c64 = DAT_00842c64 - 1, uVar4 != DAT_00842c64)) {
*(undefined4 *)(DAT_00842c5c + uVar4 * 4) =
*(undefined4 *)(DAT_00842c5c + DAT_00842c64 * 4);
}
if (pvVar1 == (void *)0x0) {
return;
}
operator_delete(pvVar1);
return;
}
uVar4 = uVar4 + 1;
} while (uVar4 < DAT_00842c64);
}
piVar2 = (int *)FUN_005df0f5(0x14);
*piVar2 = param_1;
piVar2[1] = (int)param_2;
piVar2[2] = (int)param_3;
piVar2[3] = 0;
piVar2[4] = 0;
if (DAT_00842c60 <= DAT_00842c64) {
if (DAT_00842c60 == 0) {
iVar3 = 8;
}
else {
iVar3 = DAT_00842c60 * 2;
}
iVar3 = FUN_00500570(iVar3);
if (iVar3 == 0) {
return;
}
}
*(int **)(DAT_00842c5c + DAT_00842c64 * 4) = piVar2;
DAT_00842c64 = DAT_00842c64 + 1;
return;
}
// --- FUN_0050a720 at 0x0050A720 (size: 87) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_0050a720(float *param_1,float *param_2)
{
if (_DAT_007c7618 < ABS(param_1[2])) {
param_2[2] = 0.0;
param_2[2] = -(param_1[2] * DAT_00796344 + *param_2 * *param_1 + param_2[1] * param_1[1] +
param_1[3]) * ((float)_DAT_007938c0 / param_1[2]) -
-param_1[3] * ((float)_DAT_007938c0 / param_1[2]);
}
return;
}
// --- FUN_0050a780 at 0x0050A780 (size: 39) ---
void __thiscall FUN_0050a780(undefined4 *param_1,undefined4 *param_2)
{
*param_1 = *param_2;
param_1[1] = param_2[1];
param_1[2] = param_2[2];
param_1[3] = param_2[3];
return;
}
// --- FUN_0050a7b0 at 0x0050A7B0 (size: 35) ---
void __thiscall FUN_0050a7b0(int param_1,undefined4 *param_2)
{
*(undefined4 *)(param_1 + 0x1c4) = *param_2;
*(undefined4 *)(param_1 + 0x1c8) = param_2[1];
*(undefined4 *)(param_1 + 0x1cc) = param_2[2];
*(undefined4 *)(param_1 + 0x1d0) = param_2[3];
return;
}
// --- FUN_0050a7e0 at 0x0050A7E0 (size: 67) ---
void __thiscall FUN_0050a7e0(int param_1,float *param_2)
{
*(undefined4 *)(param_1 + 0x234) = 0;
*(float *)(param_1 + 0x148) = *(float *)(param_1 + 0x148) + *param_2;
*(float *)(param_1 + 0x14c) = param_2[1] + *(float *)(param_1 + 0x14c);
*(float *)(param_1 + 0x150) = param_2[2] + *(float *)(param_1 + 0x150);
FUN_0050d2e0();
return;
}
// --- FUN_0050a830 at 0x0050A830 (size: 32) ---
void __fastcall FUN_0050a830(undefined4 *param_1)
{
*param_1 = 0;
param_1[6] = 0;
param_1[0xe] = 0;
param_1[0x12] = 0;
param_1[0x19] = 0;
param_1[0x1e] = 0;
param_1[0x1f] = 0;
param_1[0xb] = 0;
param_1[0x20] = 0;
return;
}
// --- FUN_0050a850 at 0x0050A850 (size: 56) ---
void __thiscall FUN_0050a850(int param_1,undefined4 *param_2,undefined4 param_3)
{
*(undefined4 *)(param_1 + 0x18) = 1;
*(undefined4 *)(param_1 + 0x1c) = *param_2;
*(undefined4 *)(param_1 + 0x20) = param_2[1];
*(undefined4 *)(param_1 + 0x24) = param_2[2];
*(undefined4 *)(param_1 + 0x28) = param_2[3];
*(undefined4 *)(param_1 + 0x34) = param_3;
return;
}
// --- FUN_0050a890 at 0x0050A890 (size: 7) ---
void FUN_0050a890(void)
{
DAT_00842c6c = DAT_00842c6c + -1;
return;
}
// --- FUN_0050a8a0 at 0x0050A8A0 (size: 97) ---
void __fastcall FUN_0050a8a0(undefined4 *param_1)
{
*param_1 = 0;
param_1[1] = 0;
param_1[7] = 0;
FUN_0050ce00();
param_1[0x9c] = 0;
param_1[0xa2] = 0;
param_1[0xaa] = 0;
param_1[0xae] = 0;
param_1[0xb5] = 0;
param_1[0xba] = 0;
param_1[0xbb] = 0;
param_1[0xa7] = 0;
param_1[0xbc] = 0;
param_1[0xbf] = 0;
param_1[0xbd] = 0;
param_1[0xbe] = 0;
return;
}
// --- thunk_FUN_0050da00 at 0x0050A910 (size: 5) ---
void __thiscall thunk_FUN_0050da00(int *param_1,int param_2,int param_3)
{
int *piVar1;
int iVar2;
float10 fVar3;
*param_1 = param_2;
param_1[1] = param_3;
param_1[2] = *(int *)(param_2 + 0x114);
fVar3 = (float10)FUN_0050f4d0();
param_1[3] = (int)(float)fVar3;
fVar3 = (float10)FUN_0050f4f0();
param_1[4] = (int)(float)fVar3;
iVar2 = *param_1;
param_1[5] = *(uint *)(iVar2 + 0xa8) & 4;
param_1[6] = ~(*(uint *)(iVar2 + 0xa8) >> 6) & 1;
piVar1 = *(int **)(iVar2 + 300);
if (piVar1 != (int *)0x0) {
iVar2 = (**(code **)(*piVar1 + 0x28))();
if (iVar2 != 0) {
param_1[1] = param_1[1] | 0x80;
}
iVar2 = (**(code **)(*piVar1 + 0x10))();
if (iVar2 != 0) {
param_1[1] = param_1[1] | 0x100;
}
iVar2 = (**(code **)(*piVar1 + 0x20))();
if (iVar2 != 0) {
param_1[1] = param_1[1] | 0x800;
}
iVar2 = (**(code **)(*piVar1 + 0x24))();
if (iVar2 != 0) {
param_1[1] = param_1[1] | 0x1000;
}
}
return;
}
// --- FUN_0050a920 at 0x0050A920 (size: 8) ---
void FUN_0050a920(void)
{
FUN_0050d140();
return;
}
// --- FUN_0050a930 at 0x0050A930 (size: 8) ---
void FUN_0050a930(void)
{
FUN_0050d8f0();
return;
}
// --- FUN_0050a940 at 0x0050A940 (size: 96) ---
undefined4 __thiscall FUN_0050a940(int param_1,int *param_2,int param_3)
{
undefined4 uVar1;
int iVar2;
if (param_2 == (int *)0x0) {
uVar1 = 2;
}
else {
iVar2 = 0;
uVar1 = 1;
if (0 < param_3) {
do {
uVar1 = (**(code **)(*param_2 + 0x88))(param_1);
switch(uVar1) {
case 1:
case 2:
goto switchD_0050a973_caseD_1;
case 4:
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
default:
iVar2 = iVar2 + 1;
if (param_3 <= iVar2) {
return uVar1;
}
}
} while( true );
}
}
switchD_0050a973_caseD_1:
return uVar1;
}
// --- FUN_0050a9b0 at 0x0050A9B0 (size: 47) ---
void __thiscall FUN_0050a9b0(int param_1,undefined4 param_2)
{
*(undefined4 *)(param_1 + 0x254) = 1;
*(undefined4 *)(param_1 + 0x1d0) = 0;
FUN_0052c570(param_1 + 0x2f4,param_2,param_1 + 0x20);
return;
}
// --- FUN_0050a9e0 at 0x0050A9E0 (size: 78) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __thiscall FUN_0050a9e0(float *param_1,float *param_2)
{
if (((ABS(*param_1 - *param_2) < _DAT_007c7618 != (ABS(*param_1 - *param_2) == _DAT_007c7618)) &&
(ABS(param_1[1] - param_2[1]) < _DAT_007c7618 !=
(ABS(param_1[1] - param_2[1]) == _DAT_007c7618))) &&
(ABS(param_1[2] - param_2[2]) < _DAT_007c7618 !=
(ABS(param_1[2] - param_2[2]) == _DAT_007c7618))) {
return 1;
}
return 0;
}
// --- FUN_0050aa30 at 0x0050AA30 (size: 100) ---
void __thiscall FUN_0050aa30(int param_1,float *param_2,int param_3)
{
float fVar1;
float fVar2;
float fVar3;
float fVar4;
float local_18;
float local_14;
float local_10;
FUN_0043e7d0(&local_18,*(undefined4 *)(param_1 + 4),*(undefined4 *)(param_3 + 4));
fVar1 = *(float *)(param_3 + 0x40);
fVar2 = *(float *)(param_3 + 0x44);
fVar3 = *(float *)(param_1 + 0x40);
fVar4 = *(float *)(param_1 + 0x44);
*param_2 = (local_18 + *(float *)(param_3 + 0x3c)) - *(float *)(param_1 + 0x3c);
param_2[1] = (local_14 + fVar1) - fVar3;
param_2[2] = (local_10 + fVar2) - fVar4;
return;
}
// --- FUN_0050aaa0 at 0x0050AAA0 (size: 34) ---
undefined4 __thiscall FUN_0050aaa0(int param_1,undefined4 param_2)
{
FUN_0043e7d0(param_2,*(undefined4 *)(param_1 + 0xa4),*(undefined4 *)(param_1 + 0x110));
return param_2;
}
// --- FUN_0050aad0 at 0x0050AAD0 (size: 96) ---
void __thiscall FUN_0050aad0(int param_1,undefined4 *param_2)
{
int iVar1;
*(undefined4 *)(param_1 + 0x48) = 1;
*(undefined4 *)(param_1 + 0x4c) = *param_2;
*(undefined4 *)(param_1 + 0x50) = param_2[1];
*(undefined4 *)(param_1 + 0x54) = param_2[2];
iVar1 = FUN_004524a0();
if (iVar1 != 0) {
*(undefined4 *)(param_1 + 0x4c) = 0;
*(undefined4 *)(param_1 + 0x50) = 0;
*(undefined4 *)(param_1 + 0x54) = 0;
}
return;
}
// --- FUN_0050ab30 at 0x0050AB30 (size: 71) ---
void __thiscall FUN_0050ab30(int param_1,undefined4 *param_2)
{
int iVar1;
*(undefined4 *)(param_1 + 0x38) = 1;
*(undefined4 *)(param_1 + 0x3c) = *param_2;
*(undefined4 *)(param_1 + 0x40) = param_2[1];
*(undefined4 *)(param_1 + 0x44) = 0;
iVar1 = FUN_004524a0();
if (iVar1 != 0) {
*(undefined4 *)(param_1 + 0x3c) = 0;
*(undefined4 *)(param_1 + 0x40) = 0;
*(undefined4 *)(param_1 + 0x44) = 0;
}
return;
}
// --- FUN_0050ab80 at 0x0050AB80 (size: 593) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_0050ab80(int param_1,float *param_2,float *param_3,int *param_4)
{
float fVar1;
float fVar2;
float fVar3;
float *pfVar4;
int iVar5;
double dVar6;
undefined1 local_c [8];
float local_4;
if (*(int *)(param_1 + 0xb4) == 0) {
*param_2 = 0.0;
param_2[1] = 0.0;
param_2[2] = 0.0;
*param_3 = 0.0;
param_3[1] = 0.0;
param_3[2] = 0.0;
*param_4 = 1;
return;
}
pfVar4 = (float *)FUN_0050aa30(local_c,*(undefined4 *)(param_1 + 0xb8));
*param_2 = *pfVar4;
param_2[1] = pfVar4[1];
param_2[2] = pfVar4[2];
fVar1 = *(float *)(*(int *)(param_1 + 0x24) + 0xc);
fVar2 = SQRT(param_2[2] * param_2[2] + param_2[1] * param_2[1] + *param_2 * *param_2);
if ((*(byte *)(param_1 + 4) & 4) != 0) {
if (_DAT_007c7618 < fVar2) {
fVar2 = fVar2 / fVar1;
fVar3 = _DAT_007938b0 / fVar2;
fVar1 = param_2[1];
local_4 = fVar3 * param_2[2];
*param_3 = fVar3 * *param_2;
param_3[1] = fVar3 * fVar1;
param_3[2] = local_4;
floor((double)fVar2);
iVar5 = FUN_005df4c4();
*param_4 = iVar5 + 1;
return;
}
*param_3 = 0.0;
param_3[1] = 0.0;
param_3[2] = 0.0;
*param_4 = 0;
return;
}
fVar2 = fVar2 / (_DAT_007c7614 * fVar1);
if (fVar2 < _DAT_007938b0 == (fVar2 == _DAT_007938b0)) {
dVar6 = ceil((double)fVar2);
fVar2 = _DAT_007938b0 / (float)dVar6;
fVar1 = param_2[1];
local_4 = fVar2 * param_2[2];
*param_3 = fVar2 * *param_2;
param_3[1] = fVar2 * fVar1;
param_3[2] = local_4;
iVar5 = FUN_005df4c4();
*param_4 = iVar5;
return;
}
if (((*param_2 == DAT_00796344) && (param_2[1] == DAT_00796344)) && (param_2[2] == DAT_00796344))
{
*param_3 = 0.0;
param_3[1] = 0.0;
param_3[2] = 0.0;
*param_4 = 0;
return;
}
*param_3 = *param_2;
param_3[1] = param_2[1];
param_3[2] = param_2[2];
*param_4 = 1;
return;
}
// --- FUN_0050ad5f at 0x0050AD5F (size: 100) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void FUN_0050ad5f(void)
{
float fVar1;
float fVar2;
float fVar3;
undefined4 uVar4;
float *unaff_ESI;
float10 in_ST0;
double dVar5;
float *in_stack_00000028;
undefined4 *in_stack_0000002c;
dVar5 = ceil((double)in_ST0);
fVar3 = _DAT_007938b0 / (float)dVar5;
fVar1 = unaff_ESI[1];
fVar2 = unaff_ESI[2];
*in_stack_00000028 = fVar3 * *unaff_ESI;
in_stack_00000028[1] = fVar3 * fVar1;
in_stack_00000028[2] = fVar3 * fVar2;
uVar4 = FUN_005df4c4();
*in_stack_0000002c = uVar4;
return;
}
// --- FUN_0050ae40 at 0x0050AE40 (size: 858) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_0050ae40(int param_1,float *param_2,float *param_3)
{
float *pfVar1;
float *pfVar2;
float fVar3;
bool bVar4;
int iVar5;
float local_24;
float local_20;
float local_1c;
float local_18;
float local_14;
float local_10;
float local_4;
local_20 = param_3[1];
local_24 = *param_3;
local_1c = param_3[2];
bVar4 = false;
if (*(int *)(param_1 + 0x2a8) != 0) {
if (local_24 * *(float *)(param_1 + 0x2ac) +
local_20 * *(float *)(param_1 + 0x2b0) + local_1c * *(float *)(param_1 + 0x2b4) <
DAT_00796344) {
bVar4 = true;
}
else {
*(undefined4 *)(param_1 + 0x2a8) = 0;
}
}
if (*(int *)(param_1 + 0x288) == 0) {
if (bVar4) {
fVar3 = local_20 * *(float *)(param_1 + 0x2b0) +
local_1c * *(float *)(param_1 + 0x2b4) + local_24 * *(float *)(param_1 + 0x2ac);
local_24 = local_24 - fVar3 * *(float *)(param_1 + 0x2ac);
local_20 = local_20 - fVar3 * *(float *)(param_1 + 0x2b0);
local_1c = local_1c - fVar3 * *(float *)(param_1 + 0x2b4);
}
}
else {
pfVar1 = (float *)(param_1 + 0x28c);
fVar3 = local_24 * *pfVar1 +
local_20 * *(float *)(param_1 + 0x290) + local_1c * *(float *)(param_1 + 0x294);
if (bVar4) {
local_18 = *(float *)(param_1 + 0x2b4) * *(float *)(param_1 + 0x290) -
*(float *)(param_1 + 0x2b0) * *(float *)(param_1 + 0x294);
local_14 = *(float *)(param_1 + 0x2ac) * *(float *)(param_1 + 0x294) -
*(float *)(param_1 + 0x2b4) * *pfVar1;
local_10 = *(float *)(param_1 + 0x2b0) * *pfVar1 -
*(float *)(param_1 + 0x2ac) * *(float *)(param_1 + 0x290);
iVar5 = FUN_004524a0();
if (iVar5 == 0) {
local_1c = local_18 * local_24 + local_14 * local_20 + local_10 * local_1c;
local_24 = local_18 * local_1c;
local_20 = local_14 * local_1c;
local_1c = local_10 * local_1c;
local_18 = local_24;
local_14 = local_20;
local_10 = local_1c;
local_4 = local_1c;
}
else {
local_18 = 0.0;
local_14 = 0.0;
local_10 = 0.0;
local_24 = 0.0;
local_20 = 0.0;
local_1c = 0.0;
}
}
else if (fVar3 <= DAT_00796344) {
local_4 = fVar3 * *(float *)(param_1 + 0x294);
local_24 = local_24 - fVar3 * *pfVar1;
local_20 = local_20 - fVar3 * *(float *)(param_1 + 0x290);
local_1c = local_1c - local_4;
local_18 = local_24;
local_14 = local_20;
local_10 = local_1c;
}
else {
FUN_0050a720(&local_24);
}
if ((*(int *)(param_1 + 0x2a4) == 0) && (*(int *)(param_1 + 0x29c) != 0)) {
FUN_0043e7d0(&local_18,*(undefined4 *)(param_1 + 0x130),*(int *)(param_1 + 0x29c));
pfVar2 = *(float **)(param_1 + 0x34);
fVar3 = (*pfVar2 - local_18) * *pfVar1 +
(pfVar2[1] - local_14) * *(float *)(param_1 + 0x290) +
(pfVar2[2] - local_10) * *(float *)(param_1 + 0x294) + *(float *)(param_1 + 0x298);
if ((fVar3 < pfVar2[3] - _DAT_007c7618) &&
(local_10 = (pfVar2[3] - fVar3) / *(float *)(param_1 + 0x294), ABS(local_10) < pfVar2[3]))
{
local_18 = 0.0;
local_14 = 0.0;
FUN_0050a7e0(&local_18);
}
}
}
*param_2 = local_24;
param_2[1] = local_20;
param_2[2] = local_1c;
return;
}
// --- FUN_0050b1a0 at 0x0050B1A0 (size: 425) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __thiscall FUN_0050b1a0(int param_1,float *param_2)
{
float *pfVar1;
float fVar2;
float fVar3;
float fVar4;
float fVar5;
int iVar6;
float *pfVar7;
float unaff_ESI;
float local_28;
float local_24;
float local_20;
float local_1c;
float local_10;
float local_c;
float local_4;
fVar2 = param_2[1] * *(float *)(param_1 + 0x27c) - param_2[2] * *(float *)(param_1 + 0x278);
fVar4 = *(float *)(param_1 + 0x274) * param_2[2] - *(float *)(param_1 + 0x27c) * *param_2;
fVar3 = (*param_2 * *(float *)(param_1 + 0x278) - param_2[1] * *(float *)(param_1 + 0x274)) *
DAT_00796344;
fVar5 = fVar3 - fVar4;
fVar3 = fVar2 - fVar3;
local_28 = fVar4 * DAT_00796344 - fVar2 * DAT_00796344;
iVar6 = FUN_004524a0();
if (iVar6 != 0) {
return 1;
}
FUN_0043e7d0(&local_24,*(undefined4 *)(param_1 + 0xc4),*(undefined4 *)(param_1 + 0x130));
pfVar7 = *(float **)(param_1 + 0x34);
pfVar1 = *(float **)(param_1 + 0x58);
local_10 = pfVar7[2] - pfVar1[2];
local_c = local_24 + (*pfVar7 - *pfVar1);
local_1c = local_c * fVar5 +
(local_20 + (pfVar7[1] - pfVar1[1])) * fVar3 + (local_1c + local_10) * local_28;
if (local_1c <= (float)_DAT_00795610) {
local_24 = fVar5 * local_1c;
local_20 = fVar3 * local_1c;
local_1c = local_28 * local_1c;
local_4 = local_1c;
FUN_0050a7e0(&local_24);
pfVar7 = (float *)&stack0xffffffcc;
}
else {
local_1c = -local_1c;
local_24 = fVar5 * local_1c;
local_20 = fVar3 * local_1c;
local_1c = local_28 * local_1c;
local_4 = local_1c;
FUN_0050a7e0(&local_24);
pfVar7 = &local_28;
local_28 = -unaff_ESI;
local_24 = -fVar5;
local_20 = -fVar3;
}
FUN_0050aad0(pfVar7);
return 3;
}
// --- FUN_0050b350 at 0x0050B350 (size: 43) ---
void __fastcall FUN_0050b350(int param_1)
{
*(undefined4 *)(param_1 + 0x160) = *(undefined4 *)(param_1 + 0x108);
*(undefined4 *)(param_1 + 0x168) = *(undefined4 *)(param_1 + 0x110);
FUN_00425f10(param_1 + 0x114);
return;
}
// --- FUN_0050b380 at 0x0050B380 (size: 64) ---
void __thiscall FUN_0050b380(int param_1,int param_2,undefined4 param_3)
{
*(undefined4 *)(param_1 + 0x110) = *(undefined4 *)(param_2 + 4);
FUN_00425f10(param_2 + 8);
*(undefined4 *)(param_1 + 0x108) = param_3;
*(undefined4 *)(param_1 + 0x234) = 0;
FUN_0050d2e0(0);
return;
}
// --- FUN_0050b3c0 at 0x0050B3C0 (size: 41) ---
undefined4 * __thiscall FUN_0050b3c0(int param_1,undefined4 *param_2)
{
*param_2 = &PTR_LAB_00797910;
param_2[1] = *(undefined4 *)(param_1 + 0x1ec);
FUN_00425f10(param_1 + 0x1f0);
return param_2;
}
// --- FUN_0050b3f0 at 0x0050B3F0 (size: 93) ---
undefined4 * __fastcall FUN_0050b3f0(undefined4 *param_1)
{
undefined4 *puVar1;
undefined4 *puVar2;
param_1[2] = 0;
puVar1 = (undefined4 *)thunk_FUN_005df0f5(0x44);
if (puVar1 == (undefined4 *)0x0) {
puVar2 = (undefined4 *)0x0;
}
else {
puVar2 = puVar1 + 1;
*puVar1 = 8;
FUN_00401000(puVar2,8,8,FUN_0050a140);
}
param_1[3] = puVar2;
param_1[5] = 0;
param_1[6] = 8;
param_1[4] = 8;
param_1[2] = 0;
*param_1 = 0;
param_1[1] = 0;
param_1[4] = 8;
return param_1;
}
// --- FUN_0050b450 at 0x0050B450 (size: 127) ---
undefined4 * __fastcall FUN_0050b450(undefined4 *param_1)
{
*param_1 = 0;
param_1[1] = 0;
param_1[7] = 0;
FUN_0050cf50();
param_1[0xb6] = 0;
param_1[0xb9] = 0;
param_1[0xb8] = 0;
param_1[0xb7] = 0x80;
param_1[0x9c] = 0;
param_1[0xa2] = 0;
param_1[0xaa] = 0;
param_1[0xae] = 0;
param_1[0xb5] = 0;
param_1[0xba] = 0;
param_1[0xbb] = 0;
param_1[0xa7] = 0;
param_1[0xbc] = 0;
FUN_0050b3f0();
FUN_0050a8a0();
return param_1;
}
// --- FUN_0050b4d0 at 0x0050B4D0 (size: 102) ---
bool __fastcall FUN_0050b4d0(int param_1)
{
undefined4 uVar1;
int iVar2;
uVar1 = *(undefined4 *)(param_1 + 0xbc);
*(undefined4 *)(param_1 + 0x174) = 1;
*(undefined4 *)(param_1 + 0x130) = *(undefined4 *)(param_1 + 0xc4);
FUN_00425f10(param_1 + 200);
*(undefined4 *)(param_1 + 0x128) = uVar1;
*(undefined4 *)(param_1 + 0x254) = 0;
FUN_0050d2e0(0);
iVar2 = FUN_0050fb20(param_1);
return iVar2 != 1;
}
// --- FUN_0050b540 at 0x0050B540 (size: 834) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
int __thiscall FUN_0050b540(int *param_1,int param_2,undefined4 *param_3)
{
float *pfVar1;
bool bVar2;
int iVar3;
undefined4 local_10;
undefined4 local_c;
undefined4 local_8;
float local_4;
*param_3 = 0;
bVar2 = true;
if (param_2 == 1) {
if (param_1[0x4c] == param_1[0x31]) {
iVar3 = FUN_00424e90(param_1 + 0x32);
if (iVar3 != 0) goto LAB_0050b590;
}
}
else {
LAB_0050b590:
bVar2 = false;
if (param_2 != 1) {
if ((1 < param_2) && (param_2 < 5)) {
if (param_1[0x9c] != 0) {
FUN_0050dab0();
pfVar1 = (float *)param_1[0x16];
if (ABS(*pfVar1 * (float)param_1[0x9d] +
pfVar1[1] * (float)param_1[0x9e] + pfVar1[2] * (float)param_1[0x9f] +
(float)param_1[0xa0]) < _DAT_007c7618 + *(float *)(param_1[0xd] + 0xc)) {
FUN_0050a850(param_1 + 0x9d,param_1[0xa1]);
param_1[0xa7] = param_1[0xa8];
if ((*(byte *)(param_1 + 1) & 2) != 0) {
bVar2 = true;
}
}
}
if (param_1[0xae] == 0) {
local_10 = 0;
local_c = 0;
local_8 = 0x3f800000;
FUN_0050aad0(&local_10);
}
FUN_0050b380(param_1 + 0x30,param_1[0x2f]);
FUN_0050a9b0(0);
param_2 = 1;
}
goto LAB_0050b6e9;
}
}
iVar3 = param_1[0x4a];
param_1[0x31] = param_1[0x4c];
FUN_00425f10(param_1 + 0x4d);
param_1[0x2f] = iVar3;
FUN_0050d210();
iVar3 = param_1[0x2f];
param_1[0x4c] = param_1[0x31];
FUN_00425f10(param_1 + 0x32);
param_1[0x4a] = iVar3;
param_1[0x95] = 0;
FUN_0050d2e0(0);
LAB_0050b6e9:
if (param_1[0xae] != 0) {
FUN_0050ab30(param_1 + 0xaf);
}
if (((*(byte *)(param_1 + 1) & 4) == 0) && ((*(uint *)(*param_1 + 0xa8) & 0x400) != 0)) {
if (bVar2) {
param_1[0xbc] = 0;
}
else if (param_1[0xbc] == 0) {
param_1[0xbc] = 1;
}
else if (param_1[0xbc] == 1) {
param_1[0xbc] = 2;
}
else {
pfVar1 = (float *)param_1[0xd];
param_1[0xbc] = 3;
local_10 = 0;
local_c = 0;
local_8 = 0x3f800000;
local_4 = pfVar1[3] - ((pfVar1[1] + *pfVar1) * DAT_00796344 + pfVar1[2]);
FUN_0050a850(&local_10,0);
param_1[0xa7] = param_1[0x4c];
if ((*(byte *)(param_1 + 1) & 1) == 0) {
FUN_0050aad0(&local_10);
param_1[0xbb] = 1;
}
}
}
param_1[0x9c] = param_1[0xa2];
if (param_1[0xa2] != 0) {
param_1[0x9d] = param_1[0xa3];
param_1[0x9e] = param_1[0xa4];
param_1[0x9f] = param_1[0xa5];
param_1[0xa0] = param_1[0xa6];
param_1[0xa8] = param_1[0xa7];
param_1[0xa1] = param_1[0xa9];
}
if (param_1[0xa2] != 0) {
param_1[1] = param_1[1] | 1;
iVar3 = FUN_0050d9e0(param_1 + 0xa3);
if (iVar3 != 0) {
param_1[1] = param_1[1] | 2;
return param_2;
}
param_1[1] = param_1[1] & 0xfffffffd;
return param_2;
}
param_1[1] = param_1[1] & 0xfffffffc;
return param_2;
}
// --- FUN_0050b890 at 0x0050B890 (size: 130) ---
int __thiscall FUN_0050b890(int param_1,int param_2,undefined4 *param_3)
{
int iVar1;
*param_3 = 0;
iVar1 = *(int *)(param_1 + 0x128);
if (iVar1 == 0) {
return 2;
}
if (param_2 == 1) {
*(undefined4 *)(param_1 + 0xc4) = *(undefined4 *)(param_1 + 0x130);
FUN_00425f10(param_1 + 0x134);
*(int *)(param_1 + 0xbc) = iVar1;
FUN_0050d210();
}
else if (((1 < param_2) && (param_2 < 5)) && (*(int *)(param_1 + 0x26c) != 0)) {
FUN_0050a830();
return param_2;
}
return param_2;
}
// --- FUN_0050b920 at 0x0050B920 (size: 386) ---
undefined4 __thiscall FUN_0050b920(int param_1,int *param_2)
{
int *piVar1;
uint uVar2;
undefined4 uVar3;
int local_4c;
undefined **ppuStack_48;
uint uStack_44;
undefined1 auStack_40 [52];
undefined1 auStack_c [12];
uVar2 = 0;
uVar3 = 1;
local_4c = 0;
*(undefined4 *)(param_1 + 0x254) = 1;
*(undefined4 *)(param_1 + 0x1d0) = 0;
FUN_0052c570(param_1 + 0x2f4,&local_4c,param_1 + 0x20);
if (*(int *)(param_1 + 0x2fc) != 0) {
do {
piVar1 = *(int **)(*(int *)(param_1 + 0x300) + 4 + uVar2 * 8);
if ((piVar1 != (int *)0x0) && (piVar1 != param_2)) {
uVar3 = (**(code **)(*piVar1 + 0x88))(param_1);
switch(uVar3) {
case 2:
case 3:
goto switchD_0050b989_caseD_2;
case 4:
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
return uVar3;
}
}
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(param_1 + 0x2fc));
}
*(int *)(param_1 + 0x128) = local_4c;
if (local_4c != 0) {
FUN_0050d6d0(*(undefined4 *)(local_4c + 0x28));
return uVar3;
}
if (*(int *)(param_1 + 0x178) != 0) {
return 2;
}
uStack_44 = *(uint *)(param_1 + 0x130);
ppuStack_48 = &PTR_LAB_00797910;
FUN_00425f10(param_1 + 0x134);
if ((uStack_44 & 0xffff) < 0x100) {
FUN_005aac70(&uStack_44,auStack_c);
}
if (uStack_44 != 0) {
FUN_0050d6d0(uStack_44);
*(uint *)(param_1 + 0x130) = uStack_44;
FUN_00425f10(auStack_40);
*(undefined4 *)(param_1 + 0x128) = 0;
*(undefined4 *)(param_1 + 0x254) = 0;
FUN_0050d2e0(0);
*(undefined4 *)(param_1 + 0x254) = 1;
return uVar3;
}
uVar3 = 2;
switchD_0050b989_caseD_2:
return uVar3;
}
// --- FUN_0050bac0 at 0x0050BAC0 (size: 259) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
bool __thiscall FUN_0050bac0(int param_1,undefined4 param_2)
{
float fVar1;
undefined4 uVar2;
int iVar3;
undefined4 local_54;
undefined4 local_50;
float local_4c;
undefined **local_48;
undefined4 local_44;
if ((*(byte *)(param_1 + 4) & 2) != 0) {
iVar3 = FUN_0050ceb0();
if (iVar3 == 0) {
local_44 = *(undefined4 *)(param_1 + 0x130);
uVar2 = *(undefined4 *)(param_1 + 0x128);
local_48 = &PTR_LAB_00797910;
FUN_00425f10(param_1 + 0x134);
local_4c = *(float *)(param_1 + 0x10);
*(undefined4 *)(param_1 + 0x1d8) = param_2;
*(undefined4 *)(param_1 + 0x1f8) = 1;
if ((*(uint *)(param_1 + 0x20) < 2) &&
(fVar1 = *(float *)(*(int *)(param_1 + 0x34) + 0xc), fVar1 + fVar1 < local_4c)) {
local_4c = *(float *)(*(int *)(param_1 + 0x34) + 0xc) * _DAT_007938b8;
}
fVar1 = *(float *)(*(int *)(param_1 + 0x34) + 0xc);
if (fVar1 + fVar1 < local_4c) {
local_4c = local_4c * _DAT_007938b8;
}
local_4c = -local_4c;
local_54 = 0;
local_50 = 0;
FUN_0050a7e0(&local_54);
iVar3 = FUN_0050c1c0(1);
*(undefined4 *)(param_1 + 0x1f8) = 0;
FUN_0050b380(&local_4c,uVar2);
return iVar3 != 1;
}
}
return true;
}
// --- FUN_0050bbd0 at 0x0050BBD0 (size: 68) ---
void __fastcall FUN_0050bbd0(int param_1)
{
undefined4 uVar1;
uVar1 = *(undefined4 *)(param_1 + 0x160);
*(undefined4 *)(param_1 + 0x110) = *(undefined4 *)(param_1 + 0x168);
FUN_00425f10(param_1 + 0x16c);
*(undefined4 *)(param_1 + 0x108) = uVar1;
*(undefined4 *)(param_1 + 0x234) = 0;
FUN_0050d2e0(0);
return;
}
// --- FUN_0050bc20 at 0x0050BC20 (size: 122) ---
undefined * FUN_0050bc20(void)
{
int iVar1;
if ((DAT_00844b80 & 1) == 0) {
DAT_00844b80 = DAT_00844b80 | 1;
iVar1 = 10;
do {
FUN_0050b450();
iVar1 = iVar1 + -1;
} while (iVar1 != 0);
_atexit((_func_4879 *)&LAB_00767920);
}
if (DAT_00842c6c < 10) {
iVar1 = DAT_00842c6c * 0x314;
FUN_0050a8a0();
DAT_00842c6c = DAT_00842c6c + 1;
return &DAT_00842cb8 + iVar1;
}
return (undefined *)0x0;
}
// --- FUN_0050bca0 at 0x0050BCA0 (size: 51) ---
int __fastcall FUN_0050bca0(int param_1)
{
int iVar1;
if (*(int *)(param_1 + 0x128) == 0) {
return 2;
}
iVar1 = FUN_0050a940(*(int *)(param_1 + 0x128),3);
if (iVar1 == 1) {
iVar1 = FUN_0050b920(*(undefined4 *)(param_1 + 0x128));
}
return iVar1;
}
// --- FUN_0050bce0 at 0x0050BCE0 (size: 133) ---
int __thiscall FUN_0050bce0(int param_1,int param_2,int param_3)
{
undefined4 uVar1;
int iVar2;
iVar2 = *(int *)(param_1 + 0x128);
if (iVar2 == 0) {
return 2;
}
if (param_2 == 1) {
*(undefined4 *)(param_1 + 0xc4) = *(undefined4 *)(param_1 + 0x130);
FUN_00425f10(param_1 + 0x134);
*(int *)(param_1 + 0xbc) = iVar2;
FUN_0050d210();
}
else if (((2 < param_2) && (param_2 < 5)) && (param_3 != 0)) {
uVar1 = FUN_0050bca0();
iVar2 = FUN_0050bce0(uVar1,0);
return iVar2;
}
return param_2;
}
// --- FUN_0050bd70 at 0x0050BD70 (size: 304) ---
bool __thiscall FUN_0050bd70(int param_1,float param_2,float param_3)
{
int iVar1;
undefined4 local_c;
undefined4 local_8;
float local_4;
*(undefined4 *)(param_1 + 0x268) = 0;
*(undefined4 *)(param_1 + 0x178) = 1;
*(float *)(param_1 + 0x1e0) = param_2;
*(undefined4 *)(param_1 + 0x1dc) = 0x3f800000;
if (*(int *)(param_1 + 0x114) == 0) {
*(undefined4 *)(param_1 + 0x254) = 0;
local_4 = -param_2;
*(undefined4 *)(param_1 + 0x168) = *(undefined4 *)(param_1 + 0x168);
*(float *)(param_1 + 0x170) = local_4 + *(float *)(param_1 + 0x170);
local_c = 0;
local_8 = 0;
*(undefined4 *)(param_1 + 0x16c) = *(undefined4 *)(param_1 + 0x16c);
FUN_0050d2e0(&local_c);
}
iVar1 = FUN_0050c1c0(5);
*(undefined4 *)(param_1 + 0x178) = 0;
if (((iVar1 == 1) && (*(int *)(param_1 + 0x288) != 0)) && (param_3 <= *(float *)(param_1 + 0x294))
) {
if ((((*(uint *)(param_1 + 4) & 0x200) != 0) && (*(int *)(param_1 + 0x114) == 0)) &&
(iVar1 = FUN_0050bac0(param_3), iVar1 == 0)) {
return false;
}
*(undefined4 *)(param_1 + 0x17c) = *(undefined4 *)(param_1 + 0x174);
*(undefined4 *)(param_1 + 0x174) = 1;
iVar1 = FUN_0050c1c0(1);
*(undefined4 *)(param_1 + 0x174) = *(undefined4 *)(param_1 + 0x17c);
return iVar1 == 1;
}
return false;
}
// --- FUN_0050bea0 at 0x0050BEA0 (size: 565) ---
bool __thiscall FUN_0050bea0(int param_1,int *param_2,undefined4 param_3,float param_4)
{
float *pfVar1;
float *pfVar2;
int iVar3;
undefined4 uVar4;
int *unaff_retaddr;
undefined4 uVar5;
float local_54;
float local_50;
float local_4c [19];
if (((*(uint *)(param_1 + 4) & 2) == 0) || ((*(uint *)(param_1 + 4) & 0x200) == 0)) {
*(undefined4 *)(param_1 + 500) = 0;
uVar5 = *(undefined4 *)(param_1 + 0x180);
*(undefined4 *)(param_1 + 0x130) = *(undefined4 *)(param_1 + 0x188);
FUN_00425f10(param_1 + 0x18c);
*(undefined4 *)(param_1 + 0x128) = uVar5;
*(undefined4 *)(param_1 + 0x254) = 0;
FUN_0050d2e0(0);
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
*(undefined4 *)(param_1 + 0x254) = 1;
*param_2 = 1;
return true;
}
if ((*(int *)(param_1 + 0x288) != 0) && (*(float *)(param_1 + 0x294) < param_4)) {
*(undefined4 *)(param_1 + 500) = 0;
FUN_0050bbd0();
iVar3 = FUN_0050b1a0(param_1 + 0x28c);
*param_2 = iVar3;
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
return false;
}
if (*(int *)(param_1 + 500) != 0) {
FUN_0050bbd0();
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
iVar3 = FUN_0050d750(param_1 + 0x270);
*param_2 = iVar3;
return iVar3 == 2;
}
if (*(int *)(param_1 + 0x288) == 0) {
pfVar1 = *(float **)(param_1 + 0x58);
pfVar2 = *(float **)(param_1 + 0x34);
local_4c[0] = pfVar1[2] - pfVar2[2];
local_50 = pfVar1[1] - pfVar2[1];
local_54 = *pfVar1 - *pfVar2;
FUN_0050a7e0(&local_54);
FUN_0050bd70(param_2,param_3);
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
FUN_0050bbd0();
if (*(int *)(param_1 + 500) == 0) {
*(undefined4 *)(param_1 + 500) = 0;
*unaff_retaddr = 2;
*(undefined4 *)(param_1 + 0x254) = 1;
return true;
}
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
uVar5 = *(undefined4 *)(param_1 + 0x250);
uVar4 = FUN_0050b3c0(local_4c);
FUN_0050d4a0(uVar4,uVar5);
FUN_0050a7b0(*(undefined4 *)(param_1 + 0x44));
iVar3 = FUN_0050d750(param_1 + 0x270);
*unaff_retaddr = iVar3;
return iVar3 == 2;
}
*(undefined4 *)(param_1 + 500) = 0;
FUN_0050bbd0();
*(undefined4 *)(param_1 + 0x254) = 1;
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
*param_2 = 1;
return true;
}
// --- FUN_0050c0e0 at 0x0050C0E0 (size: 214) ---
undefined4 __thiscall FUN_0050c0e0(int param_1,undefined4 *param_2)
{
float fVar1;
int iVar2;
float10 fVar3;
undefined4 local_4;
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
*(undefined4 *)(param_1 + 0x114) = 1;
*(undefined4 *)(param_1 + 0x118) = *param_2;
*(undefined4 *)(param_1 + 0x11c) = param_2[1];
fVar1 = DAT_007c7610;
*(undefined4 *)(param_1 + 0x120) = param_2[2];
local_4 = 0x3d23d70a;
param_2 = (undefined4 *)fVar1;
if ((*(byte *)(param_1 + 4) & 2) != 0) {
fVar3 = (float10)FUN_0050d9f0();
param_2 = (undefined4 *)(float)fVar3;
local_4 = *(undefined4 *)(param_1 + 0xc);
}
*(undefined4 **)(param_1 + 0x1d8) = param_2;
*(undefined4 *)(param_1 + 0x180) = *(undefined4 *)(param_1 + 0x128);
*(undefined4 *)(param_1 + 0x188) = *(undefined4 *)(param_1 + 0x130);
FUN_00425f10(param_1 + 0x134);
iVar2 = FUN_0050bd70(local_4,param_2);
*(undefined4 *)(param_1 + 0x114) = 0;
*(undefined4 *)(param_1 + 500) = 0;
if (iVar2 == 0) {
FUN_0050bbd0();
return 0;
}
return 1;
}
// --- FUN_0050c1c0 at 0x0050C1C0 (size: 847) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
int __thiscall FUN_0050c1c0(int param_1,int param_2)
{
float fVar1;
float fVar2;
bool bVar3;
float fVar4;
int iVar5;
int iVar6;
float10 fVar7;
int local_14;
float local_10;
float local_c;
int local_8;
float fStack_4;
if (*(int *)(param_1 + 0x128) == 0) {
return 1;
}
iVar6 = 0;
local_8 = 0;
if (0 < param_2) {
do {
local_14 = FUN_0050a940(*(undefined4 *)(param_1 + 0x128),param_2);
switch(local_14) {
case 1:
local_14 = FUN_0050b920(*(undefined4 *)(param_1 + 0x128));
if (local_14 != 1) {
*(undefined4 *)(param_1 + 0x268) = 0;
}
if (local_14 == 2) {
return 2;
}
break;
case 2:
*(undefined4 *)(param_1 + 0x268) = 0;
return local_14;
case 4:
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
case 3:
*(undefined4 *)(param_1 + 0x268) = 0;
}
iVar6 = local_14;
if (local_14 == 1) {
if (*(int *)(param_1 + 0x124) != 0) {
bVar3 = false;
*(undefined4 *)(param_1 + 0x124) = 0;
if ((*(int *)(param_1 + 0x288) != 0) && (iVar6 = FUN_0050bac0(DAT_007c7610), iVar6 != 0))
{
*(undefined4 *)(param_1 + 0x17c) = *(undefined4 *)(param_1 + 0x174);
*(undefined4 *)(param_1 + 0x174) = 1;
iVar6 = FUN_0050c1c0(param_2);
*(undefined4 *)(param_1 + 0x174) = *(undefined4 *)(param_1 + 0x17c);
if (iVar6 == 1) goto LAB_0050c491;
}
bVar3 = true;
LAB_0050c491:
*(undefined4 *)(param_1 + 500) = 0;
if (!bVar3) {
return 1;
}
FUN_0050bbd0();
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
if (*(int *)(param_1 + 0x270) == 0) {
FUN_0050aad0(param_1 + 0x118);
return 2;
}
FUN_0050dab0();
*(int *)(param_1 + 0x270) = 0;
return 2;
}
if (((*(int *)(param_1 + 0x268) == 0) || (*(int *)(param_1 + 0x178) != 0)) ||
(*(int *)(param_1 + 0x114) != 0)) {
if (*(int *)(param_1 + 0x288) != 0) {
return 1;
}
if ((*(uint *)(param_1 + 4) & 1) == 0) {
return 1;
}
if (*(int *)(param_1 + 0x178) != 0) {
return 1;
}
if (*(int *)(param_1 + 0x128) == 0) {
return 1;
}
if (*(int *)(param_1 + 0x18) == 0) {
return 1;
}
local_10 = 0.04;
local_c = DAT_007c7610;
if ((*(uint *)(param_1 + 4) & 2) != 0) {
fVar7 = (float10)FUN_0050d9f0();
local_c = (float)fVar7;
local_10 = *(float *)(param_1 + 0x10);
}
*(float *)(param_1 + 0x1d8) = local_c;
FUN_0050b350();
fVar4 = local_c;
if ((*(uint *)(param_1 + 0x20) < 2) &&
(fVar1 = *(float *)(*(int *)(param_1 + 0x34) + 0xc), fVar1 + fVar1 < local_10)) {
local_10 = *(float *)(*(int *)(param_1 + 0x34) + 0xc) * _DAT_007938b8;
}
fVar2 = local_10;
fVar1 = *(float *)(*(int *)(param_1 + 0x34) + 0xc);
if (local_10 <= fVar1 + fVar1) {
iVar6 = FUN_0050bd70(local_10,local_c);
}
else {
fVar2 = local_10 * _DAT_007938b8;
fStack_4 = fVar2;
iVar6 = FUN_0050bd70(fVar2,local_c);
if (iVar6 != 0) goto LAB_0050c4fa;
iVar6 = FUN_0050bd70(fVar2,fVar4);
}
if (iVar6 != 0) {
LAB_0050c4fa:
*(undefined4 *)(param_1 + 500) = 0;
return 1;
}
iVar5 = FUN_0050bea0(&local_14,fVar2,fVar4);
iVar6 = local_14;
if (iVar5 != 0) {
return local_14;
}
}
else {
*(undefined4 *)(param_1 + 0x268) = 0;
if (*(int *)(param_1 + 600) == 0) {
iVar6 = FUN_00538180(param_1 + 0x20,param_1 + 0x270,param_1 + 0x25c,
*(undefined4 *)(param_1 + 0x58));
}
else {
iVar5 = FUN_0050c0e0(param_1 + 0x25c);
if (iVar5 == 0) {
iVar6 = FUN_0050ce80(param_1,param_1 + 0x270);
}
}
}
}
local_8 = local_8 + 1;
} while (local_8 < param_2);
}
return iVar6;
}
// --- FUN_0050c520 at 0x0050C520 (size: 927) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __fastcall FUN_0050c520(int param_1)
{
float *pfVar1;
bool bVar2;
float fVar3;
undefined4 uVar4;
int iVar5;
float *pfVar6;
uint uVar7;
double dVar8;
float local_a0;
float local_9c;
float local_98;
undefined4 local_94;
float local_90;
uint local_8c;
float local_88;
uint local_84;
float local_80;
uint local_7c;
float local_78;
float local_74;
float local_70;
float local_64;
undefined4 local_60;
undefined4 local_5c;
undefined4 local_58;
undefined4 local_54;
undefined4 local_2c;
undefined4 local_28;
undefined4 local_24;
undefined1 local_20 [28];
uVar4 = *(undefined4 *)(param_1 + 0xbc);
*(undefined4 *)(param_1 + 0x130) = *(undefined4 *)(param_1 + 0xc4);
FUN_00425f10();
*(undefined4 *)(param_1 + 0x128) = uVar4;
*(undefined4 *)(param_1 + 0x254) = 0;
FUN_0050d2e0();
*(undefined4 *)(param_1 + 0x2a8) = 0;
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
uVar4 = FUN_0050c1c0();
iVar5 = FUN_0050b890(uVar4,&local_94);
if (iVar5 == 1) {
return 1;
}
if (*(int *)(param_1 + 0x26c) != 0) {
local_a0 = *(float *)(*(int *)(param_1 + 0x24) + 0xc);
bVar2 = false;
local_9c = 4.0;
if (_DAT_007c7624 <= local_a0) {
if (local_a0 < _DAT_007c7620) {
local_a0 = 0.48;
}
}
else {
bVar2 = true;
local_9c = 2.0;
}
fVar3 = _DAT_007c6f14 / (_DAT_007c7614 * local_a0);
if (bVar2) {
fVar3 = fVar3 * _DAT_007938b8;
}
if (fVar3 < _DAT_007938b0 == (fVar3 == _DAT_007938b0)) {
dVar8 = ceil((double)fVar3);
local_88 = local_9c / (float)dVar8;
local_84 = FUN_005df4c4();
local_98 = 0.0;
local_9c = 0.0;
local_8c = 0;
local_80 = (local_88 / local_a0) * _DAT_007c761c;
if (local_84 != 0) {
do {
local_98 = local_98 + local_88;
local_9c = local_80 + local_9c;
ceil((double)local_9c);
iVar5 = FUN_005df4c4();
uVar7 = iVar5 * 2;
local_90 = (float)(int)uVar7;
if ((int)uVar7 < 0) {
local_90 = local_90 + _DAT_0079920c;
}
local_90 = _DAT_0079cc60 / local_90;
local_60 = 0x3f800000;
local_5c = 0;
local_58 = 0;
local_54 = 0;
local_2c = 0;
local_28 = 0;
local_24 = 0;
local_7c = uVar7;
FUN_00535b30();
local_a0 = 0.0;
if (uVar7 != 0) {
pfVar1 = (float *)(param_1 + 0x108);
do {
local_94 = *(undefined4 *)(param_1 + 0xbc);
*(undefined4 *)(param_1 + 0x130) = *(undefined4 *)(param_1 + 0xc4);
FUN_00425f10();
*(undefined4 *)(param_1 + 0x128) = local_94;
*(undefined4 *)(param_1 + 0x254) = 0;
FUN_0050d2e0();
FUN_00536b80();
pfVar6 = (float *)FUN_00536460();
local_78 = local_98 * *pfVar6;
local_74 = local_98 * pfVar6[1];
local_70 = local_98 * pfVar6[2];
local_64 = local_70;
pfVar6 = (float *)FUN_0050ae40(local_20,&local_78);
*pfVar1 = *pfVar6;
*(float *)(param_1 + 0x10c) = pfVar6[1];
*(float *)(param_1 + 0x110) = pfVar6[2];
fVar3 = *(float *)(param_1 + 0x110) * *(float *)(param_1 + 0x110) +
*(float *)(param_1 + 0x10c) * *(float *)(param_1 + 0x10c) + *pfVar1 * *pfVar1;
if (_DAT_007c7618 * _DAT_007c7618 < fVar3 != (_DAT_007c7618 * _DAT_007c7618 == fVar3))
{
*(undefined4 *)(param_1 + 0x254) = 0;
*(float *)(param_1 + 0x168) = *(float *)(param_1 + 0x168) + *pfVar1;
*(float *)(param_1 + 0x16c) =
*(float *)(param_1 + 0x10c) + *(float *)(param_1 + 0x16c);
*(float *)(param_1 + 0x170) =
*(float *)(param_1 + 0x110) + *(float *)(param_1 + 0x170);
FUN_0050d2e0();
*(undefined4 *)(param_1 + 0x2a8) = 0;
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
uVar4 = FUN_0050c1c0();
iVar5 = FUN_0050b890(uVar4,&local_94);
if (iVar5 == 1) {
return 1;
}
}
local_a0 = (float)((int)local_a0 + 1);
} while ((uint)local_a0 < local_7c);
}
local_8c = local_8c + 1;
} while (local_8c < local_84);
return 0;
}
}
}
return 0;
}
// --- FUN_0050c8c0 at 0x0050C8C0 (size: 881) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __fastcall FUN_0050c8c0(int param_1)
{
float *pfVar1;
int iVar2;
float fVar3;
float fVar4;
float *pfVar5;
undefined4 uVar6;
uint uVar7;
uint uVar8;
uint local_48;
int local_44;
uint local_40;
float local_3c;
float local_38;
float local_34;
float local_30;
float local_2c;
float local_28;
float local_24;
float local_20;
float local_1c;
float local_10;
undefined1 local_c [12];
if (*(int *)(param_1 + 0xb0) == 0) {
return 0;
}
local_44 = 1;
local_48 = 0;
FUN_0050ab80(&local_3c,&local_24,&local_48);
if ((*(byte *)(param_1 + 4) & 0x10) != 0) {
iVar2 = *(int *)(param_1 + 0xb8);
FUN_00535dc0(*(undefined4 *)(iVar2 + 8),*(undefined4 *)(iVar2 + 0xc),
*(undefined4 *)(iVar2 + 0x10),*(undefined4 *)(iVar2 + 0x14));
}
uVar6 = *(undefined4 *)(param_1 + 0xbc);
*(undefined4 *)(param_1 + 0x130) = *(undefined4 *)(param_1 + 0xc4);
FUN_00425f10(param_1 + 200);
*(undefined4 *)(param_1 + 0x128) = uVar6;
uVar8 = 0;
*(undefined4 *)(param_1 + 0x254) = 0;
FUN_0050d2e0(0);
if (local_48 == 0) {
if ((*(byte *)(param_1 + 4) & 0x10) == 0) {
iVar2 = *(int *)(param_1 + 0xb8);
FUN_00535dc0(*(undefined4 *)(iVar2 + 8),*(undefined4 *)(iVar2 + 0xc),
*(undefined4 *)(iVar2 + 0x10),*(undefined4 *)(iVar2 + 0x14));
}
FUN_0050b380(param_1 + 0xc0,*(undefined4 *)(param_1 + 0xbc));
*(undefined4 *)(param_1 + 0x254) = 1;
*(undefined4 *)(param_1 + 0x1d0) = 0;
FUN_0052c570(param_1 + 0x2f4,0,param_1 + 0x20);
return 1;
}
if (local_48 != 0) {
pfVar1 = (float *)(param_1 + 0x108);
while( true ) {
if ((((*(byte *)(param_1 + 4) & 4) != 0) && (uVar7 = local_48 - 1, uVar8 == uVar7)) &&
(fVar3 = SQRT(local_3c * local_3c + local_38 * local_38 + local_34 * local_34),
_DAT_007c7618 < fVar3)) {
fVar4 = (float)(int)uVar7;
if ((int)uVar7 < 0) {
fVar4 = fVar4 + _DAT_0079920c;
}
fVar3 = (fVar3 - fVar4 * *(float *)(*(int *)(param_1 + 0x24) + 0xc)) / fVar3;
local_30 = local_3c * fVar3;
local_2c = local_38 * fVar3;
local_28 = local_34 * fVar3;
local_40 = uVar7;
local_24 = local_30;
local_20 = local_2c;
local_1c = local_28;
local_10 = local_28;
}
pfVar5 = (float *)FUN_0050ae40(local_c,&local_24);
*pfVar1 = *pfVar5;
*(float *)(param_1 + 0x10c) = pfVar5[1];
*(float *)(param_1 + 0x110) = pfVar5[2];
if (((*(uint *)(param_1 + 4) & 4) == 0) &&
(*(float *)(param_1 + 0x110) * *(float *)(param_1 + 0x110) +
*(float *)(param_1 + 0x10c) * *(float *)(param_1 + 0x10c) + *pfVar1 * *pfVar1 <
_DAT_007c7618 * _DAT_007c7618)) break;
if ((*(uint *)(param_1 + 4) & 0x10) == 0) {
local_40 = uVar8 + 1;
fVar3 = (float)(int)local_40;
if ((int)local_40 < 0) {
fVar3 = fVar3 + _DAT_0079920c;
}
fVar4 = (float)(int)local_48;
if ((int)local_48 < 0) {
fVar4 = fVar4 + _DAT_0079920c;
}
FUN_005360d0(*(int *)(param_1 + 0xb4) + 8,*(int *)(param_1 + 0xb8) + 8,fVar3 / fVar4);
}
*(undefined4 *)(param_1 + 0x2a8) = 0;
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
if (*(int *)(param_1 + 0x174) == 0) {
*(undefined4 *)(param_1 + 0x254) = 0;
*(float *)(param_1 + 0x168) = *pfVar1 + *(float *)(param_1 + 0x168);
*(float *)(param_1 + 0x16c) = *(float *)(param_1 + 0x10c) + *(float *)(param_1 + 0x16c);
*(float *)(param_1 + 0x170) = *(float *)(param_1 + 0x110) + *(float *)(param_1 + 0x170);
FUN_0050d2e0(pfVar1);
uVar6 = FUN_0050c1c0(3);
local_44 = FUN_0050b540(uVar6,&local_40);
if (*(int *)(param_1 + 0x2f0) != 0) goto LAB_0050cb59;
}
else {
uVar6 = FUN_0050c1c0(3);
local_44 = FUN_0050b890(uVar6,&local_40);
if (local_44 == 1) {
return 1;
}
if (*(int *)(param_1 + 0x26c) == 0) {
return 0;
}
FUN_0050a7e0(pfVar1);
}
if (((*(int *)(param_1 + 0x2b8) != 0) && ((*(byte *)(param_1 + 4) & 8) != 0)) ||
(uVar8 = uVar8 + 1, local_48 <= uVar8)) goto LAB_0050cb59;
}
if (uVar8 == 0) {
return 0;
}
LAB_0050cb59:
if (local_44 != 1) {
return 0;
}
}
return 1;
}
// --- FUN_0050cc40 at 0x0050CC40 (size: 413) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
bool __fastcall FUN_0050cc40(int param_1)
{
float fVar1;
undefined4 uVar2;
int iVar3;
undefined4 uVar4;
float local_8;
uVar2 = *(undefined4 *)(param_1 + 0xbc);
*(undefined4 *)(param_1 + 0x130) = *(undefined4 *)(param_1 + 0xc4);
FUN_00425f10(param_1 + 200);
*(undefined4 *)(param_1 + 0x128) = uVar2;
*(undefined4 *)(param_1 + 0x254) = 0;
FUN_0050d2e0(0);
*(undefined4 *)(param_1 + 0x174) = 2;
if (*(int *)(param_1 + 0x128) == 0) {
iVar3 = 2;
}
else {
iVar3 = FUN_0050a940(*(int *)(param_1 + 0x128),3);
if (iVar3 == 1) {
iVar3 = FUN_0050b920(*(undefined4 *)(param_1 + 0x128));
}
}
iVar3 = FUN_0050bce0(iVar3,1);
if (iVar3 != 1) {
return false;
}
*(undefined4 *)(param_1 + 0x174) = 1;
iVar3 = FUN_0050c520();
uVar2 = DAT_007c7610;
if (iVar3 == 0) {
return false;
}
if (*(int *)(param_1 + 0x18) == 0) goto LAB_0050cdc4;
local_8 = *(float *)(param_1 + 0x10);
*(undefined4 *)(param_1 + 0x1d8) = DAT_007c7610;
FUN_0050b350();
*(undefined4 *)(param_1 + 0x17c) = *(undefined4 *)(param_1 + 0x174);
*(undefined4 *)(param_1 + 0x174) = 0;
if ((*(uint *)(param_1 + 0x20) < 2) &&
(fVar1 = *(float *)(*(int *)(param_1 + 0x34) + 0xc), fVar1 + fVar1 < local_8)) {
local_8 = *(float *)(*(int *)(param_1 + 0x34) + 0xc) * _DAT_007938b8;
}
fVar1 = *(float *)(*(int *)(param_1 + 0x34) + 0xc);
uVar4 = DAT_007c7610;
if (local_8 <= fVar1 + fVar1) {
LAB_0050cd94:
iVar3 = FUN_0050bd70(local_8,uVar4);
if (iVar3 == 0) {
FUN_0050bbd0();
*(undefined4 *)(param_1 + 0x288) = 0;
*(undefined4 *)(param_1 + 0x2a4) = 0;
}
}
else {
local_8 = local_8 * _DAT_007938b8;
iVar3 = FUN_0050bd70(local_8,DAT_007c7610);
uVar4 = uVar2;
if (iVar3 == 0) goto LAB_0050cd94;
}
*(undefined4 *)(param_1 + 0x174) = *(undefined4 *)(param_1 + 0x17c);
*(undefined4 *)(param_1 + 500) = 0;
LAB_0050cdc4:
iVar3 = FUN_0050bce0(1,1);
return iVar3 == 1;
}
// --- FUN_0050cde0 at 0x0050CDE0 (size: 20) ---
void __fastcall FUN_0050cde0(int param_1)
{
if (*(int *)(param_1 + 0x174) == 0) {
FUN_0050c8c0();
return;
}
FUN_0050cc40();
return;
}
// --- FUN_0050ce00 at 0x0050CE00 (size: 123) ---
void __fastcall FUN_0050ce00(undefined4 *param_1)
{
*param_1 = 0;
param_1[0x24] = 0;
param_1[0x25] = 0;
param_1[0x27] = 0;
param_1[0x42] = 0;
param_1[0x55] = 0;
param_1[0x56] = 0;
param_1[0x3d] = 0;
param_1[0x41] = 0;
param_1[0x6c] = 0;
param_1[0x6d] = 0;
param_1[0x6b] = 0;
param_1[0x58] = 0;
param_1[0x6e] = 0;
param_1[0x75] = 0;
param_1[0x76] = 0;
param_1[0x8d] = 0;
param_1[0x8e] = 0;
param_1[0x92] = 0;
param_1[0x93] = 1;
return;
}
// --- FUN_0050ce80 at 0x0050CE80 (size: 46) ---
void __thiscall FUN_0050ce80(int param_1,undefined4 param_2,int param_3)
{
*(undefined4 *)(param_3 + 0x18) = 0;
*(undefined4 *)(param_3 + 0x34) = 0;
*(undefined4 *)(param_1 + 0xf4) = 0;
FUN_00538180(param_1,param_3,param_1 + 0xf8,*(undefined4 *)(param_1 + 0x38));
return;
}
// --- FUN_0050ceb0 at 0x0050CEB0 (size: 52) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __fastcall FUN_0050ceb0(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 0x1d4) == 0) {
return 1;
}
*(float *)(param_1 + 0x1d0) = *(float *)(param_1 + 0x1d0) * _DAT_007938b8;
uVar1 = FUN_00539ba0(param_1 + 0x1c4,param_1 + 0x1dc);
return uVar1;
}
// --- FUN_0050cef0 at 0x0050CEF0 (size: 82) ---
void __thiscall FUN_0050cef0(int param_1,float *param_2,float *param_3)
{
float fVar1;
float fVar2;
float fVar3;
float fVar4;
float fVar5;
float fVar6;
float fVar7;
float fVar8;
float fVar9;
float fVar10;
float fVar11;
float fVar12;
fVar1 = *(float *)(param_1 + 0x34);
fVar2 = param_3[1];
fVar3 = *(float *)(param_1 + 0x30);
fVar4 = *param_3;
fVar5 = *(float *)(param_1 + 0x38);
fVar6 = param_3[2];
fVar7 = *(float *)(param_1 + 0x28);
fVar8 = param_3[1];
fVar9 = *(float *)(param_1 + 0x24);
fVar10 = *param_3;
fVar11 = *(float *)(param_1 + 0x2c);
fVar12 = param_3[2];
*param_2 = *(float *)(param_1 + 0x20) * param_3[2] +
*(float *)(param_1 + 0x18) * *param_3 + *(float *)(param_1 + 0x1c) * param_3[1];
param_2[1] = fVar11 * fVar12 + fVar9 * fVar10 + fVar7 * fVar8;
param_2[2] = fVar5 * fVar6 + fVar3 * fVar4 + fVar1 * fVar2;
return;
}
// --- FUN_0050cf50 at 0x0050CF50 (size: 360) ---
int __fastcall FUN_0050cf50(int param_1)
{
undefined4 *puVar1;
undefined4 uVar2;
undefined4 *puVar3;
puVar3 = (undefined4 *)0x0;
*(undefined4 *)(param_1 + 0x40) = 0;
*(undefined ***)(param_1 + 0x3c) = &PTR_LAB_00797910;
*(undefined4 *)(param_1 + 0x44) = 0x3f800000;
*(undefined4 *)(param_1 + 0x48) = 0;
*(undefined4 *)(param_1 + 0x4c) = 0;
*(undefined4 *)(param_1 + 0x50) = 0;
*(undefined4 *)(param_1 + 0x78) = 0;
*(undefined4 *)(param_1 + 0x7c) = 0;
*(undefined4 *)(param_1 + 0x80) = 0;
FUN_00535b30();
*(undefined ***)(param_1 + 0xa0) = &PTR_LAB_00797910;
*(undefined4 *)(param_1 + 0xa4) = 0;
*(undefined4 *)(param_1 + 0xa8) = 0x3f800000;
*(undefined4 *)(param_1 + 0xac) = 0;
*(undefined4 *)(param_1 + 0xb0) = 0;
*(undefined4 *)(param_1 + 0xb4) = 0;
*(undefined4 *)(param_1 + 0xdc) = 0;
*(undefined4 *)(param_1 + 0xe0) = 0;
*(undefined4 *)(param_1 + 0xe4) = 0;
FUN_00535b30();
*(undefined ***)(param_1 + 0x10c) = &PTR_LAB_00797910;
*(undefined4 *)(param_1 + 0x110) = 0;
*(undefined4 *)(param_1 + 0x114) = 0x3f800000;
*(undefined4 *)(param_1 + 0x118) = 0;
*(undefined4 *)(param_1 + 0x11c) = 0;
*(undefined4 *)(param_1 + 0x120) = 0;
*(undefined4 *)(param_1 + 0x148) = 0;
*(undefined4 *)(param_1 + 0x14c) = 0;
*(undefined4 *)(param_1 + 0x150) = 0;
FUN_00535b30();
*(undefined ***)(param_1 + 0x164) = &PTR_LAB_00797910;
*(undefined4 *)(param_1 + 0x168) = 0;
*(undefined4 *)(param_1 + 0x16c) = 0x3f800000;
*(undefined4 *)(param_1 + 0x170) = 0;
*(undefined4 *)(param_1 + 0x174) = 0;
*(undefined4 *)(param_1 + 0x178) = 0;
*(undefined4 *)(param_1 + 0x1a0) = 0;
*(undefined4 *)(param_1 + 0x1a4) = 0;
*(undefined4 *)(param_1 + 0x1a8) = 0;
FUN_00535b30();
*(undefined ***)(param_1 + 0x1e8) = &PTR_LAB_00797910;
*(undefined4 *)(param_1 + 0x1ec) = 0;
*(undefined4 *)(param_1 + 0x1f0) = 0x3f800000;
*(undefined4 *)(param_1 + 500) = 0;
*(undefined4 *)(param_1 + 0x1f8) = 0;
*(undefined4 *)(param_1 + 0x1fc) = 0;
*(undefined4 *)(param_1 + 0x224) = 0;
*(undefined4 *)(param_1 + 0x228) = 0;
*(undefined4 *)(param_1 + 0x22c) = 0;
FUN_00535b30();
puVar1 = (undefined4 *)thunk_FUN_005df0f5(0x24);
if (puVar1 == (undefined4 *)0x0) {
puVar1 = (undefined4 *)0x0;
}
else {
*puVar1 = 2;
puVar1 = puVar1 + 1;
}
*(undefined4 **)(param_1 + 4) = puVar1;
puVar1 = (undefined4 *)thunk_FUN_005df0f5(0x24);
if (puVar1 == (undefined4 *)0x0) {
puVar1 = (undefined4 *)0x0;
}
else {
*puVar1 = 2;
puVar1 = puVar1 + 1;
}
*(undefined4 **)(param_1 + 0x14) = puVar1;
puVar1 = (undefined4 *)thunk_FUN_005df0f5(0x24);
if (puVar1 != (undefined4 *)0x0) {
*puVar1 = 2;
puVar3 = puVar1 + 1;
}
*(undefined4 **)(param_1 + 0x24) = puVar3;
uVar2 = thunk_FUN_005df0f5(0x18);
*(undefined4 *)(param_1 + 0x34) = uVar2;
uVar2 = thunk_FUN_005df0f5(0x18);
*(undefined4 *)(param_1 + 0x38) = uVar2;
FUN_0050ce00();
return param_1;
}
// --- FUN_0050d0c0 at 0x0050D0C0 (size: 115) ---
void __fastcall FUN_0050d0c0(int param_1)
{
if (*(int *)(param_1 + 4) != 0) {
operator_delete__((void *)(*(int *)(param_1 + 4) + -4));
}
if (*(int *)(param_1 + 0x14) != 0) {
operator_delete__((void *)(*(int *)(param_1 + 0x14) + -4));
}
if (*(int *)(param_1 + 0x24) != 0) {
operator_delete__((void *)(*(int *)(param_1 + 0x24) + -4));
}
operator_delete__(*(void **)(param_1 + 0x34));
operator_delete__(*(void **)(param_1 + 0x38));
*(undefined ***)(param_1 + 0x1e8) = &PTR_FUN_0079385c;
*(undefined ***)(param_1 + 0x164) = &PTR_FUN_0079385c;
*(undefined ***)(param_1 + 0x10c) = &PTR_FUN_0079385c;
*(undefined ***)(param_1 + 0xa0) = &PTR_FUN_0079385c;
*(undefined ***)(param_1 + 0x3c) = &PTR_FUN_0079385c;
return;
}
// --- FUN_0050d140 at 0x0050D140 (size: 203) ---
void __thiscall FUN_0050d140(uint *param_1,uint param_2,int param_3,float param_4)
{
float fVar1;
float fVar2;
uint *puVar3;
float *pfVar4;
float *pfVar5;
uint uVar6;
if (param_2 < 3) {
*param_1 = param_2;
}
else {
*param_1 = 2;
}
uVar6 = 0;
if (*param_1 != 0) {
pfVar4 = (float *)(param_3 + 8);
do {
fVar1 = pfVar4[-1];
fVar2 = *pfVar4;
pfVar5 = (float *)((int)pfVar4 + param_1[1] + -param_3 + -8);
*pfVar5 = param_4 * pfVar4[-2];
pfVar5[1] = param_4 * fVar1;
pfVar5[2] = param_4 * fVar2;
uVar6 = uVar6 + 1;
*(float *)((int)pfVar4 + param_1[1] + -param_3 + 4) = param_4 * pfVar4[1];
pfVar4 = pfVar4 + 4;
} while (uVar6 < *param_1);
}
puVar3 = (uint *)param_1[1];
fVar1 = (float)puVar3[3];
uVar6 = puVar3[1];
fVar2 = (float)puVar3[2];
param_1[2] = *puVar3;
param_1[3] = uVar6;
param_1[4] = (uint)(fVar2 - fVar1);
return;
}
// --- FUN_0050d210 at 0x0050D210 (size: 195) ---
void __fastcall FUN_0050d210(uint *param_1)
{
float *pfVar1;
float fVar2;
float fVar3;
float fVar4;
float fVar5;
float fVar6;
float fVar7;
float fVar8;
float fVar9;
float fVar10;
float fVar11;
float fVar12;
float fVar13;
float fVar14;
float fVar15;
float *pfVar16;
float *pfVar17;
int iVar18;
int iVar19;
uint uVar20;
uVar20 = 0;
if (*param_1 != 0) {
iVar19 = 0;
iVar18 = 0;
do {
pfVar1 = (float *)(param_1[1] + iVar18);
pfVar16 = (float *)(param_1[1] + iVar18);
iVar18 = iVar18 + 0x10;
fVar2 = (float)param_1[0x35];
fVar3 = pfVar16[2];
fVar4 = *pfVar16;
fVar5 = (float)param_1[0x2f];
fVar6 = (float)param_1[0x32];
fVar7 = pfVar16[1];
fVar8 = (float)param_1[0x38];
fVar9 = (float)param_1[0x36];
fVar10 = pfVar16[2];
fVar11 = (float)param_1[0x33];
fVar12 = pfVar16[1];
fVar13 = (float)param_1[0x30];
fVar14 = *pfVar16;
pfVar17 = (float *)(param_1[0xe] + iVar19);
uVar20 = uVar20 + 1;
iVar19 = iVar19 + 0xc;
fVar15 = (float)param_1[0x39];
*pfVar17 = pfVar16[2] * (float)param_1[0x34] +
pfVar16[1] * (float)param_1[0x31] + *pfVar1 * (float)param_1[0x2e] +
(float)param_1[0x37];
pfVar17[1] = fVar6 * fVar7 + fVar4 * fVar5 + fVar2 * fVar3 + fVar8;
pfVar17[2] = fVar13 * fVar14 + fVar11 * fVar12 + fVar9 * fVar10 + fVar15;
} while (uVar20 < *param_1);
}
return;
}
// --- FUN_0050d2e0 at 0x0050D2E0 (size: 440) ---
void __thiscall FUN_0050d2e0(uint *param_1,float *param_2)
{
float *pfVar1;
float fVar2;
float fVar3;
float fVar4;
float fVar5;
float fVar6;
float fVar7;
float fVar8;
float fVar9;
float fVar10;
float fVar11;
float fVar12;
float fVar13;
float fVar14;
float fVar15;
float *pfVar16;
float *pfVar17;
uint uVar18;
int iVar19;
uVar18 = 0;
if (param_2 != (float *)0x0) {
if (*param_1 != 0) {
iVar19 = 0;
do {
pfVar1 = (float *)(param_1[5] + iVar19);
pfVar16 = (float *)(param_1[5] + iVar19);
uVar18 = uVar18 + 1;
iVar19 = iVar19 + 0x10;
*pfVar16 = *pfVar1 + *param_2;
pfVar16[1] = param_2[1] + pfVar16[1];
pfVar16[2] = param_2[2] + pfVar16[2];
} while (uVar18 < *param_1);
}
param_1[6] = (uint)(*param_2 + (float)param_1[6]);
param_1[7] = (uint)(param_2[1] + (float)param_1[7]);
param_1[8] = (uint)(param_2[2] + (float)param_1[8]);
return;
}
if (*param_1 != 0) {
iVar19 = 0;
do {
*(undefined4 *)(iVar19 + 0xc + param_1[5]) = *(undefined4 *)(iVar19 + 0xc + param_1[1]);
pfVar1 = (float *)(param_1[1] + iVar19);
pfVar16 = (float *)(param_1[1] + iVar19);
fVar2 = (float)param_1[0x50];
fVar3 = pfVar16[2];
fVar4 = *pfVar16;
fVar5 = (float)param_1[0x4a];
fVar6 = (float)param_1[0x4d];
fVar7 = pfVar16[1];
fVar8 = (float)param_1[0x53];
fVar9 = (float)param_1[0x51];
fVar10 = pfVar16[2];
fVar11 = (float)param_1[0x4b];
fVar12 = *pfVar16;
fVar13 = (float)param_1[0x4e];
fVar14 = pfVar16[1];
pfVar17 = (float *)(param_1[5] + iVar19);
uVar18 = uVar18 + 1;
iVar19 = iVar19 + 0x10;
fVar15 = (float)param_1[0x54];
*pfVar17 = pfVar16[2] * (float)param_1[0x4f] +
pfVar16[1] * (float)param_1[0x4c] + *pfVar1 * (float)param_1[0x49] +
(float)param_1[0x52];
pfVar17[1] = fVar6 * fVar7 + fVar4 * fVar5 + fVar2 * fVar3 + fVar8;
pfVar17[2] = fVar13 * fVar14 + fVar11 * fVar12 + fVar9 * fVar10 + fVar15;
} while (uVar18 < *param_1);
}
param_1[6] = (uint)((float)param_1[0x4c] * (float)param_1[3] +
(float)param_1[0x49] * (float)param_1[2] +
(float)param_1[0x4f] * (float)param_1[4] + (float)param_1[0x52]);
param_1[7] = (uint)((float)param_1[0x4d] * (float)param_1[3] +
(float)param_1[0x4a] * (float)param_1[2] +
(float)param_1[0x50] * (float)param_1[4] + (float)param_1[0x53]);
param_1[8] = (uint)((float)param_1[0x4e] * (float)param_1[3] +
(float)param_1[0x4b] * (float)param_1[2] +
(float)param_1[0x51] * (float)param_1[4] + (float)param_1[0x54]);
return;
}
// --- FUN_0050d4a0 at 0x0050D4A0 (size: 559) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_0050d4a0(uint *param_1,int param_2,float param_3)
{
float fVar1;
float fVar2;
float fVar3;
float fVar4;
float *pfVar5;
float *pfVar6;
int iVar7;
int iVar8;
uint local_4c;
undefined1 local_18 [12];
undefined1 local_c [12];
param_3 = _DAT_007938b0 / param_3;
iVar7 = 0;
local_4c = 0;
if (*param_1 != 0) {
iVar8 = 0;
do {
*(float *)(iVar8 + 0xc + param_1[9]) = param_3 * *(float *)(iVar8 + 0xc + param_1[1]);
pfVar5 = (float *)FUN_00452830(local_18,param_1 + 0x43,param_1[1] + iVar8);
pfVar6 = (float *)(param_1[9] + iVar8);
fVar1 = pfVar5[1];
fVar2 = pfVar5[2];
*pfVar6 = param_3 * *pfVar5;
pfVar6[1] = param_3 * fVar1;
pfVar6[2] = param_3 * fVar2;
pfVar5 = (float *)FUN_00452830(local_c,param_1 + 0x28,param_1[1] + iVar8);
pfVar6 = (float *)(param_1[0xd] + iVar7);
fVar1 = pfVar5[1];
iVar8 = iVar8 + 0x10;
iVar7 = iVar7 + 0xc;
fVar2 = pfVar5[2];
*pfVar6 = param_3 * *pfVar5;
pfVar6[1] = param_3 * fVar1;
pfVar6[2] = param_3 * fVar2;
local_4c = local_4c + 1;
} while (local_4c < *param_1);
}
param_1[0x10] = *(uint *)(param_2 + 4);
param_1[0x1e] = *(uint *)(param_2 + 0x3c);
param_1[0x1f] = *(uint *)(param_2 + 0x40);
param_1[0x20] = *(uint *)(param_2 + 0x44);
param_1[0x11] = *(uint *)(param_2 + 8);
param_1[0x12] = *(uint *)(param_2 + 0xc);
param_1[0x13] = *(uint *)(param_2 + 0x10);
param_1[0x14] = *(uint *)(param_2 + 0x14);
param_1[0x15] = *(uint *)(param_2 + 0x18);
param_1[0x16] = *(uint *)(param_2 + 0x1c);
param_1[0x17] = *(uint *)(param_2 + 0x20);
param_1[0x18] = *(uint *)(param_2 + 0x24);
param_1[0x19] = *(uint *)(param_2 + 0x28);
param_1[0x1a] = *(uint *)(param_2 + 0x2c);
param_1[0x1b] = *(uint *)(param_2 + 0x30);
param_1[0x1c] = *(uint *)(param_2 + 0x34);
param_1[0x1d] = *(uint *)(param_2 + 0x38);
fVar3 = (*(float *)(param_2 + 0x28) + *(float *)(param_2 + 0x24)) * DAT_00796344;
fVar1 = *(float *)(param_2 + 0x2c);
fVar4 = (*(float *)(param_2 + 0x34) + *(float *)(param_2 + 0x30)) * DAT_00796344;
fVar2 = *(float *)(param_2 + 0x38);
param_1[0x21] =
(uint)((*(float *)(param_2 + 0x1c) + *(float *)(param_2 + 0x18)) * DAT_00796344 +
*(float *)(param_2 + 0x20));
param_1[0x22] = (uint)(fVar3 + fVar1);
param_1[0x23] = (uint)(fVar4 + fVar2);
pfVar5 = (float *)param_1[9];
fVar1 = pfVar5[3];
fVar2 = pfVar5[1];
fVar3 = pfVar5[2];
param_1[10] = (uint)(*pfVar5 - fVar1 * (float)param_1[0x21]);
param_1[0xb] = (uint)(fVar2 - fVar1 * (float)param_1[0x22]);
param_1[0xc] = (uint)(fVar3 - fVar1 * (float)param_1[0x23]);
return;
}
// --- FUN_0050d6d0 at 0x0050D6D0 (size: 120) ---
void __thiscall FUN_0050d6d0(int param_1,uint param_2)
{
float local_c;
float local_8;
float local_4;
if ((param_2 & 0xffff) < 0x100) {
FUN_0043e7d0(&local_c,param_2,*(undefined4 *)(param_1 + 0x110));
FUN_0050d2e0(&local_c);
*(float *)(param_1 + 0x148) = local_c + *(float *)(param_1 + 0x148);
*(float *)(param_1 + 0x14c) = local_8 + *(float *)(param_1 + 0x14c);
*(float *)(param_1 + 0x150) = local_4 + *(float *)(param_1 + 0x150);
}
*(uint *)(param_1 + 0x110) = param_2;
return;
}
// --- FUN_0050d750 at 0x0050D750 (size: 404) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __thiscall FUN_0050d750(int param_1,undefined4 param_2)
{
float *pfVar1;
float *pfVar2;
int iVar3;
undefined4 uVar4;
float local_3c;
float local_38;
float local_34;
float local_30;
float local_2c;
float local_28;
float local_24;
float local_20;
float local_1c;
float local_10;
float local_c;
iVar3 = FUN_0053a040(param_1 + 0x1c4,param_1 + 0x1dc,&local_3c);
if (iVar3 == 0) {
*(undefined4 *)(param_1 + 0x1d4) = 0;
return 2;
}
*(undefined4 *)(param_1 + 0x1d4) = 0;
*(undefined4 *)(param_1 + 0xf4) = 0;
pfVar1 = *(float **)(param_1 + 0x38);
pfVar2 = *(float **)(param_1 + 0x14);
local_30 = local_38 * *(float *)(param_1 + 0x20c) +
local_3c * *(float *)(param_1 + 0x200) + local_34 * *(float *)(param_1 + 0x218);
local_2c = local_38 * *(float *)(param_1 + 0x210) +
local_3c * *(float *)(param_1 + 0x204) + local_34 * *(float *)(param_1 + 0x21c);
local_34 = local_38 * *(float *)(param_1 + 0x214) +
local_3c * *(float *)(param_1 + 0x208) + local_34 * *(float *)(param_1 + 0x220);
local_3c = local_30;
local_38 = local_2c;
local_28 = local_34;
FUN_0043e7d0(&local_24,*(undefined4 *)(param_1 + 0xa4),*(undefined4 *)(param_1 + 0x110));
local_10 = pfVar2[2] - pfVar1[2];
local_c = local_24 + (*pfVar2 - *pfVar1);
if (DAT_00796344 <
local_c * local_30 +
(local_20 + (pfVar2[1] - pfVar1[1])) * local_2c + local_28 * (local_1c + local_10)) {
local_3c = local_30 * _DAT_0079a1a0;
local_38 = local_38 * _DAT_0079a1a0;
local_34 = local_34 * _DAT_0079a1a0;
}
uVar4 = FUN_00538180(param_1,param_2,&local_3c,pfVar1);
return uVar4;
}
// --- FUN_0050d8f0 at 0x0050D8F0 (size: 142) ---
void __thiscall FUN_0050d8f0(int param_1,undefined4 param_2,int param_3,int param_4)
{
*(undefined4 *)(param_1 + 0x90) = param_2;
*(int *)(param_1 + 0x94) = param_3;
*(int *)(param_1 + 0x98) = param_4;
if (param_3 != 0) {
*(undefined4 *)(param_1 + 0xa4) = *(undefined4 *)(param_3 + 4);
FUN_00425f10(param_3 + 8);
*(undefined4 *)(param_1 + 0x9c) = param_2;
FUN_0050d210();
*(undefined4 *)(param_1 + 0x154) = 0;
return;
}
*(undefined4 *)(param_1 + 0xa4) = *(undefined4 *)(param_4 + 4);
FUN_00425f10(param_4 + 8);
*(undefined4 *)(param_1 + 0x9c) = param_2;
FUN_0050d210();
*(undefined4 *)(param_1 + 0x154) = 1;
return;
}
// --- FUN_0050d980 at 0x0050D980 (size: 92) ---
undefined4 __thiscall FUN_0050d980(int *param_1,int param_2)
{
int *piVar1;
int iVar2;
if ((*(uint *)(param_2 + 0xa8) & 0x40) != 0) {
return 1;
}
if (((*(byte *)(*param_1 + 0xa8) & 0x40) != 0) && (*(int *)(param_2 + 8) != param_1[7])) {
piVar1 = *(int **)(param_2 + 300);
if (((*(uint *)(param_2 + 0xa8) & 4) != 0) && (piVar1 != (int *)0x0)) {
return 1;
}
if (((param_1[7] != 0) && (piVar1 != (int *)0x0)) &&
(iVar2 = (**(code **)(*piVar1 + 0x2c))(), iVar2 != 0)) {
return 1;
}
}
return 0;
}
// --- FUN_0050d9e0 at 0x0050D9E0 (size: 7) ---
void FUN_0050d9e0(void)
{
FUN_00510000();
return;
}
// --- FUN_0050d9f0 at 0x0050D9F0 (size: 7) ---
void FUN_0050d9f0(void)
{
FUN_00510030();
return;
}
// --- FUN_0050da00 at 0x0050DA00 (size: 162) ---
void __thiscall FUN_0050da00(int *param_1,int param_2,int param_3)
{
int *piVar1;
int iVar2;
float10 fVar3;
*param_1 = param_2;
param_1[1] = param_3;
param_1[2] = *(int *)(param_2 + 0x114);
fVar3 = (float10)FUN_0050f4d0();
param_1[3] = (int)(float)fVar3;
fVar3 = (float10)FUN_0050f4f0();
param_1[4] = (int)(float)fVar3;
iVar2 = *param_1;
param_1[5] = *(uint *)(iVar2 + 0xa8) & 4;
param_1[6] = ~(*(uint *)(iVar2 + 0xa8) >> 6) & 1;
piVar1 = *(int **)(iVar2 + 300);
if (piVar1 != (int *)0x0) {
iVar2 = (**(code **)(*piVar1 + 0x28))();
if (iVar2 != 0) {
param_1[1] = param_1[1] | 0x80;
}
iVar2 = (**(code **)(*piVar1 + 0x10))();
if (iVar2 != 0) {
param_1[1] = param_1[1] | 0x100;
}
iVar2 = (**(code **)(*piVar1 + 0x20))();
if (iVar2 != 0) {
param_1[1] = param_1[1] | 0x800;
}
iVar2 = (**(code **)(*piVar1 + 0x24))();
if (iVar2 != 0) {
param_1[1] = param_1[1] | 0x1000;
}
}
return;
}
// --- FUN_0050dab0 at 0x0050DAB0 (size: 45) ---
void FUN_0050dab0(void)
{
undefined4 local_c;
undefined4 local_8;
undefined4 local_4;
local_c = 0;
local_8 = 0;
local_4 = 0;
FUN_00511ec0(&local_c,0);
return;
}
// --- FUN_0050dae0 at 0x0050DAE0 (size: 786) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __thiscall
FUN_0050dae0(int param_1,float *param_2,float *param_3,undefined4 param_4,float param_5,int param_6,
int param_7,undefined4 param_8)
{
float fVar1;
float *pfVar2;
float fVar3;
int iVar4;
undefined4 local_1c;
float local_18;
float local_14;
float local_10;
float local_4;
local_1c = 1;
if ((*(byte *)(param_1 + 4) & 4) != 0) {
local_10 = (param_2[2] * param_3[2] + param_3[1] * param_2[1] + *param_3 * *param_2 + param_3[3]
) - param_2[3];
if (local_10 <= -_DAT_007c76f8) {
pfVar2 = *(float **)(param_6 + 0x38);
local_10 = local_10 /
((param_2[1] - pfVar2[1]) * param_3[1] +
(*param_2 - *pfVar2) * *param_3 + (param_2[2] - pfVar2[2]) * param_3[2]);
if ((((local_10 < DAT_00796344 == (local_10 == DAT_00796344)) &&
(local_10 <= (float)_DAT_007938c0)) || (*(int *)(param_6 + 0x94) == 0)) ||
((*(uint *)(*(int *)(param_6 + 0x94) + 4) & 0xffff) < 0x100)) {
local_10 = -local_10;
local_18 = (*param_2 - *pfVar2) * local_10;
local_14 = (param_2[1] - pfVar2[1]) * local_10;
local_10 = (param_2[2] - pfVar2[2]) * local_10;
local_4 = local_10;
FUN_0050a7e0(&local_18);
FUN_0050aad0(param_3);
*(undefined4 *)(param_6 + 0x7c) = 1;
return 3;
}
}
return 1;
}
param_5 = *param_2 * *param_3 + (param_2[2] - param_2[3]) * param_3[2] + param_2[1] * param_3[1] +
param_3[3] + param_5;
if (-_DAT_007c76f8 <= param_5) {
if (_DAT_007c76f8 < param_5) {
return 1;
}
iVar4 = FUN_00510000(param_3);
if (((*(int *)(param_6 + 0x158) != 0) || ((*(byte *)(param_1 + 4) & 2) == 0)) || (iVar4 != 0)) {
FUN_0050a850(param_3,param_4);
*(undefined4 *)(param_7 + 0x2c) = param_8;
}
if (((*(byte *)(param_1 + 4) & 1) == 0) && (*(int *)(param_6 + 0x158) == 0)) {
FUN_0050aad0(param_3);
*(undefined4 *)(param_7 + 0x7c) = 1;
}
local_1c = 1;
}
else {
if (*(int *)(param_6 + 0x1d8) != 0) {
return 2;
}
fVar1 = param_3[2];
iVar4 = FUN_00510000(param_3);
if (((*(int *)(param_6 + 0x158) != 0) || ((*(byte *)(param_1 + 4) & 2) == 0)) || (iVar4 != 0)) {
FUN_0050a850(param_3,param_4);
*(undefined4 *)(param_7 + 0x2c) = param_8;
if (*(int *)(param_6 + 0x158) != 0) {
fVar3 = ((float)_DAT_007938c0 -
(_DAT_0079a1a0 / (*(float *)(param_6 + 0x1c0) * *(float *)(param_6 + 0x1bc))) *
(param_5 / fVar1)) * *(float *)(param_6 + 0x1bc);
if ((*(float *)(param_6 + 0x1bc) <= fVar3) || (fVar3 < (float)_DAT_007c7700)) {
return 2;
}
*(float *)(param_6 + 0x1bc) = fVar3;
}
local_10 = -(param_5 / fVar1);
local_18 = 0.0;
local_14 = 0.0;
FUN_0050a7e0(&local_18);
local_1c = 3;
}
if (((*(byte *)(param_1 + 4) & 1) == 0) && (*(int *)(param_6 + 0x158) == 0)) {
FUN_0050aad0(param_3);
*(undefined4 *)(param_7 + 0x7c) = 1;
return local_1c;
}
}
return local_1c;
}
// --- FUN_0050de00 at 0x0050DE00 (size: 256) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_0050de00(undefined4 *param_1,undefined4 *param_2,float *param_3)
{
float *pfVar1;
float fVar2;
*param_1 = *param_2;
param_1[1] = param_2[1];
param_1[2] = param_2[2];
if (((ABS(*param_3 - _DAT_00844c18) < _DAT_007c7798 !=
(ABS(*param_3 - _DAT_00844c18) == _DAT_007c7798)) &&
(ABS(param_3[1] - _DAT_00844c1c) < _DAT_007c7798 !=
(ABS(param_3[1] - _DAT_00844c1c) == _DAT_007c7798))) &&
(ABS(param_3[2] - _DAT_00844c20) < _DAT_007c7798 !=
(ABS(param_3[2] - _DAT_00844c20) == _DAT_007c7798))) {
param_1[6] = 0;
param_1[3] = 0;
param_1[4] = 0x3f800000;
param_1[5] = 0;
return;
}
pfVar1 = (float *)(param_1 + 3);
param_1[6] = SQRT(*param_3 * *param_3 + param_3[1] * param_3[1] + param_3[2] * param_3[2]);
fVar2 = _DAT_007938b0 / (float)param_1[6];
*pfVar1 = *param_3;
param_1[4] = param_3[1];
param_1[5] = param_3[2];
*pfVar1 = fVar2 * *pfVar1;
param_1[4] = fVar2 * (float)param_1[4];
param_1[5] = fVar2 * (float)param_1[5];
return;
}
// --- FUN_0050df00 at 0x0050DF00 (size: 90) ---
void FUN_0050df00(float *param_1)
{
DAT_0081fec0 = *param_1;
DAT_0081fec4 = param_1[1];
DAT_0081fec8 = param_1[2];
DAT_0081fc84 = DAT_0081fec0;
if (DAT_0081fec0 < DAT_0081fec4) {
DAT_0081fc84 = DAT_0081fec4;
}
if (DAT_0081fc84 < DAT_0081fec8) {
DAT_0081fc84 = DAT_0081fec8;
}
return;
}
// --- FUN_0050df60 at 0x0050DF60 (size: 17) ---
undefined4 __fastcall FUN_0050df60(int param_1)
{
if (*(int *)(param_1 + 0xe0) != 0) {
return *(undefined4 *)(*(int *)(param_1 + 0xe0) + 8);
}
return 0;
}
// --- FUN_0050df80 at 0x0050DF80 (size: 27) ---
undefined4 __fastcall FUN_0050df80(int param_1)
{
if ((*(int *)(param_1 + 0xe0) != 0) && (*(int *)(param_1 + 0xe0) == DAT_00844d68)) {
return 1;
}
return 0;
}
// --- FUN_0050dfa0 at 0x0050DFA0 (size: 22) ---
undefined4 __fastcall FUN_0050dfa0(int param_1)
{
return CONCAT31((int3)((uint)*(int *)(param_1 + 0xdc) >> 8),
*(int *)(param_1 + 0xdc) == *(int *)(DAT_00870340 + 0xb0));
}
// --- FUN_0050dfc0 at 0x0050DFC0 (size: 18) ---
void __fastcall FUN_0050dfc0(int param_1)
{
*(undefined4 *)(param_1 + 0xdc) = *(undefined4 *)(DAT_00870340 + 0xb0);
return;
}
// --- FUN_0050dfe0 at 0x0050DFE0 (size: 21) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
float10 __fastcall FUN_0050dfe0(int param_1)
{
float10 fVar1;
if (*(int *)(param_1 + 0x10) != 0) {
fVar1 = (float10)FUN_0051ede0();
return fVar1;
}
return (float10)_DAT_007a61c0;
}
// --- FUN_0050e000 at 0x0050E000 (size: 97) ---
void FUN_0050e000(int *param_1,int *param_2)
{
int *piVar1;
uint uVar2;
uint uVar3;
piVar1 = (int *)*param_1;
uVar2 = 1;
if (piVar1 != (int *)0x0) {
uVar2 = piVar1[0xe];
(**(code **)(*piVar1 + 0x14))();
*param_1 = 0;
}
if (*param_2 != 0) {
uVar3 = 0;
if (uVar2 != 0) {
do {
piVar1 = *(int **)(*param_2 + uVar3 * 4);
if (piVar1 != (int *)0x0) {
(**(code **)(*piVar1 + 0x14))();
*(undefined4 *)(*param_2 + uVar3 * 4) = 0;
}
uVar3 = uVar3 + 1;
} while (uVar3 < uVar2);
}
operator_delete__((void *)*param_2);
*param_2 = 0;
}
return;
}
// --- FUN_0050e070 at 0x0050E070 (size: 15) ---
void __thiscall FUN_0050e070(int param_1,undefined4 *param_2)
{
*param_2 = *(undefined4 *)(param_1 + 200);
return;
}
// --- FUN_0050e080 at 0x0050E080 (size: 77) ---
void __fastcall FUN_0050e080(int param_1)
{
uint uVar1;
uVar1 = 0;
if (*(int *)(**(int **)(param_1 + 0x20) + 0x34) != 0) {
do {
FUN_00536ca0();
uVar1 = uVar1 + 1;
} while (uVar1 < *(uint *)(**(int **)(param_1 + 0x20) + 0x34));
}
if (*(int *)(param_1 + 0xd8) != 0) {
FUN_0053ed10(*(int *)(param_1 + 0xd8));
*(undefined4 *)(param_1 + 0xd8) = 0;
}
return;
}
// --- FUN_0050e0d0 at 0x0050E0D0 (size: 11) ---
int __fastcall FUN_0050e0d0(int param_1)
{
return **(int **)(param_1 + 0x20) + 0x98;
}
// --- FUN_0050e0e0 at 0x0050E0E0 (size: 29) ---
void __thiscall FUN_0050e0e0(int param_1,int param_2)
{
if (param_2 != 0) {
*(uint *)(param_1 + 0x1c) = *(uint *)(param_1 + 0x1c) | 1;
return;
}
*(uint *)(param_1 + 0x1c) = *(uint *)(param_1 + 0x1c) & 0xfffffffe;
return;
}
// --- FUN_0050e100 at 0x0050E100 (size: 106) ---
bool __fastcall FUN_0050e100(int param_1)
{
int iVar1;
undefined4 uVar2;
iVar1 = *(int *)(**(int **)(param_1 + 0x20) + 0x30);
if (*(int *)(param_1 + 0xc0) != iVar1) {
return true;
}
if (iVar1 == 0) {
iVar1 = FUN_005df0f5(0x50);
if (iVar1 != 0) {
uVar2 = FUN_0053a4b0();
goto LAB_0050e155;
}
}
else {
iVar1 = FUN_005df0f5(0x50);
if (iVar1 != 0) {
uVar2 = FUN_0053a500(*(undefined4 *)(**(int **)(param_1 + 0x20) + 0x30));
goto LAB_0050e155;
}
}
uVar2 = 0;
LAB_0050e155:
*(undefined4 *)(param_1 + 0xc0) = uVar2;
return *(int *)(param_1 + 0xc0) != 0;
}
// --- FUN_0050e170 at 0x0050E170 (size: 142) ---
undefined4 __fastcall FUN_0050e170(int param_1)
{
int iVar1;
undefined4 uVar2;
uint uVar3;
if (*(int *)(param_1 + 0xc4) != *(int *)(**(int **)(param_1 + 0x20) + 0x38)) {
return 1;
}
iVar1 = thunk_FUN_005df0f5(*(int *)(**(int **)(param_1 + 0x20) + 0x34) * 4);
*(int *)(param_1 + 0xc4) = iVar1;
if (iVar1 != 0) {
iVar1 = *(int *)(**(int **)(param_1 + 0x20) + 0x38);
uVar3 = 0;
if (*(int *)(**(int **)(param_1 + 0x20) + 0x34) != 0) {
do {
uVar2 = FUN_00536ff0(*(undefined4 *)(iVar1 + uVar3 * 4));
*(undefined4 *)(*(int *)(param_1 + 0xc4) + uVar3 * 4) = uVar2;
if (*(int *)(*(int *)(param_1 + 0xc4) + uVar3 * 4) == 0) {
return 0;
}
uVar3 = uVar3 + 1;
} while (uVar3 < *(uint *)(**(int **)(param_1 + 0x20) + 0x34));
}
return 1;
}
return 0;
}
// --- FUN_0050e200 at 0x0050E200 (size: 100) ---
void __fastcall FUN_0050e200(int param_1)
{
int iVar1;
uint uVar2;
if (((*(int **)(param_1 + 0x20) != (int *)0x0) && (iVar1 = **(int **)(param_1 + 0x20), iVar1 != 0)
) && (*(int *)(param_1 + 0xc4) != *(int *)(iVar1 + 0x38))) {
uVar2 = 0;
if (*(int *)(iVar1 + 0x34) != 0) {
do {
FUN_00536c10(*(undefined4 *)(*(int *)(param_1 + 0xc4) + uVar2 * 4));
uVar2 = uVar2 + 1;
} while (uVar2 < *(uint *)(**(int **)(param_1 + 0x20) + 0x34));
}
operator_delete__(*(void **)(param_1 + 0xc4));
*(undefined4 *)(param_1 + 0xc4) = *(undefined4 *)(**(int **)(param_1 + 0x20) + 0x38);
}
return;
}
// --- FUN_0050e270 at 0x0050E270 (size: 245) ---
void __thiscall FUN_0050e270(int param_1,int param_2)
{
uint uVar1;
int iVar2;
if (((*(byte *)(param_1 + 0x1c) & 1) == 0) &&
((param_2 != 0 || (*(int *)(param_1 + 0xdc) != DAT_00870340[0x2c])))) {
uVar1 = *(uint *)(param_1 + 0x14);
if ((*(int *)(param_1 + 0x10) == 0) || (*(uint *)(*(int *)(param_1 + 0x10) + 0x38) <= uVar1)) {
uVar1 = 0;
}
iVar2 = *(int *)(*(int *)(param_1 + 0x20) + uVar1 * 4);
if (iVar2 != 0) {
FUN_005a0ff0(*(undefined4 *)(param_1 + 0xc0),0);
FUN_0054c3c0(*(undefined4 *)(param_1 + 0xc4));
FUN_0050df00(param_1 + 0x24);
if (((*(int *)(param_1 + 0xe0) != 0) && (*(int *)(*(int *)(param_1 + 0xe0) + 8) != 0)) ||
(DAT_00867348 = 0, DAT_00844c04 != 0)) {
DAT_00867348 = 1;
}
DAT_008ee3d8 = param_1;
iVar2 = (**(code **)(*DAT_00870340 + 0x70))(iVar2,param_1 + 0x78,param_2 != 0);
DAT_008ee3d8 = 0;
if ((iVar2 == 2) && (DAT_00844bfc != 0)) {
if (*(int *)(param_1 + 0xe0) == 0) {
iVar2 = 0;
}
else {
iVar2 = *(int *)(*(int *)(param_1 + 0xe0) + 8);
}
if (DAT_00844bfc == iVar2) {
DAT_00844c00 = 1;
}
}
}
}
return;
}
// --- FUN_0050e370 at 0x0050E370 (size: 34) ---
bool __fastcall FUN_0050e370(int param_1)
{
int iVar1;
iVar1 = *(int *)(param_1 + 0x10);
if ((iVar1 != 0) && (*(int *)(iVar1 + 0x38) != 0)) {
return *(int *)(*(int *)(iVar1 + 0x3c) + 4) != 1;
}
return false;
}
// --- FUN_0050e3a0 at 0x0050E3A0 (size: 65) ---
undefined4 __thiscall FUN_0050e3a0(int param_1,undefined4 param_2)
{
undefined4 uVar1;
uVar1 = 1;
if ((**(int **)(param_1 + 0x20) != 0) && (*(int *)(**(int **)(param_1 + 0x20) + 0x78) != 0)) {
FUN_0050d4a0(param_1 + 0x30,*(undefined4 *)(param_1 + 0x2c));
uVar1 = FUN_00535440(param_2,*(undefined4 *)(param_1 + 0x2c));
}
return uVar1;
}
// --- FUN_0050e3f0 at 0x0050E3F0 (size: 191) ---
void __thiscall FUN_0050e3f0(int param_1,float *param_2,int param_3,float *param_4)
{
float fVar1;
float fVar2;
float fVar3;
float fVar4;
float fVar5;
float fVar6;
float fVar7;
float fVar8;
float fVar9;
float fVar10;
float fVar11;
float fVar12;
float fVar13;
float fVar14;
float fVar15;
float fVar16;
float local_24;
float local_20;
float local_1c;
FUN_0043e7d0(&local_24,*(undefined4 *)(param_1 + 4),*(undefined4 *)(param_3 + 4));
fVar1 = *(float *)(param_3 + 0x28);
fVar2 = param_4[1];
fVar3 = *(float *)(param_3 + 0x1c);
fVar4 = *param_4;
fVar5 = *(float *)(param_3 + 0x34);
fVar6 = param_4[2];
fVar7 = *(float *)(param_3 + 0x40);
fVar8 = *(float *)(param_3 + 0x2c);
fVar9 = param_4[1];
fVar10 = *(float *)(param_3 + 0x20);
fVar11 = *param_4;
fVar12 = *(float *)(param_3 + 0x38);
fVar13 = param_4[2];
fVar14 = *(float *)(param_3 + 0x44);
fVar15 = *(float *)(param_1 + 0x40);
fVar16 = *(float *)(param_1 + 0x44);
*param_2 = (local_24 +
*(float *)(param_3 + 0x30) * param_4[2] +
*(float *)(param_3 + 0x18) * *param_4 + *(float *)(param_3 + 0x24) * param_4[1] +
*(float *)(param_3 + 0x3c)) - *(float *)(param_1 + 0x3c);
param_2[1] = (local_20 + fVar5 * fVar6 + fVar3 * fVar4 + fVar1 * fVar2 + fVar7) - fVar15;
param_2[2] = (local_1c + fVar12 * fVar13 + fVar10 * fVar11 + fVar8 * fVar9 + fVar14) - fVar16;
return;
}
// --- FUN_0050e4b0 at 0x0050E4B0 (size: 158) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __fastcall FUN_0050e4b0(int param_1)
{
int iVar1;
float10 fVar2;
if (((*(int **)(param_1 + 0x20) == (int *)0x0) || (iVar1 = **(int **)(param_1 + 0x20), iVar1 == 0)
) || (*(int *)(iVar1 + 0x30) == 0)) {
fVar2 = (float10)DAT_00796344;
}
else {
fVar2 = (float10)FUN_0053a450();
}
if (fVar2 == (float10)*(float *)(param_1 + 0xcc)) {
if (((*(int **)(param_1 + 0x20) == (int *)0x0) ||
(iVar1 = **(int **)(param_1 + 0x20), iVar1 == 0)) || (*(int *)(iVar1 + 0x30) == 0)) {
fVar2 = (float10)_DAT_007938b0;
}
else {
fVar2 = (float10)FUN_0069f540();
}
if (fVar2 == (float10)*(float *)(param_1 + 0xd0)) {
if (((*(int **)(param_1 + 0x20) == (int *)0x0) ||
(iVar1 = **(int **)(param_1 + 0x20), iVar1 == 0)) || (*(int *)(iVar1 + 0x30) == 0)) {
fVar2 = (float10)DAT_00796344;
}
else {
fVar2 = (float10)FUN_0053a480();
}
if (fVar2 == (float10)*(float *)(param_1 + 0xd4)) {
return 1;
}
}
}
return 0;
}
// --- FUN_0050e550 at 0x0050E550 (size: 237) ---
undefined4 * __fastcall FUN_0050e550(undefined4 *param_1)
{
undefined4 uVar1;
param_1[8] = 0;
param_1[9] = 0x3f800000;
param_1[10] = 0x3f800000;
param_1[0xb] = 0x3f800000;
param_1[0xc] = &PTR_LAB_00797910;
param_1[0xd] = 0;
param_1[0xe] = 0x3f800000;
param_1[0xf] = 0;
param_1[0x10] = 0;
param_1[0x11] = 0;
param_1[0x1b] = 0;
param_1[0x1c] = 0;
param_1[0x1d] = 0;
FUN_00535b30();
param_1[0x1e] = &PTR_LAB_00797910;
param_1[0x1f] = 0;
param_1[0x20] = 0x3f800000;
param_1[0x21] = 0;
param_1[0x22] = 0;
param_1[0x23] = 0;
param_1[0x2d] = 0;
param_1[0x2e] = 0;
param_1[0x2f] = 0;
FUN_00535b30();
param_1[1] = 0;
param_1[2] = 0;
param_1[0x38] = 0;
param_1[5] = 0;
param_1[4] = 0;
param_1[7] = 0;
param_1[0x30] = 0;
param_1[0x31] = 0;
param_1[0x36] = 0;
param_1[0x39] = 0xffffffff;
param_1[6] = 1;
param_1[3] = 0x3f800000;
*param_1 = 0x7f7fffff;
uVar1 = DAT_00844c6c;
param_1[0x37] = 0;
param_1[0x32] = uVar1;
return param_1;
}
// --- FUN_0050e640 at 0x0050E640 (size: 258) ---
undefined4 __thiscall FUN_0050e640(int param_1,int param_2)
{
uint uVar1;
undefined4 *puVar2;
undefined4 uVar3;
uint uVar4;
puVar2 = (undefined4 *)thunk_FUN_005df0f5(4);
*(undefined4 **)(param_1 + 0x20) = puVar2;
*puVar2 = **(undefined4 **)(param_2 + 0x20);
(**(code **)(*(int *)**(undefined4 **)(param_1 + 0x20) + 0x10))();
*(undefined4 *)(param_1 + 0x24) = *(undefined4 *)(param_2 + 0x24);
*(undefined4 *)(param_1 + 0x28) = *(undefined4 *)(param_2 + 0x28);
*(undefined4 *)(param_1 + 0x2c) = *(undefined4 *)(param_2 + 0x2c);
*(undefined4 *)(param_1 + 0x34) = *(undefined4 *)(param_2 + 0x34);
FUN_00425f10(param_2 + 0x38);
*(undefined4 *)(param_1 + 0x7c) = *(undefined4 *)(param_2 + 0x7c);
FUN_00425f10(param_2 + 0x80);
*(undefined4 *)(param_1 + 200) = *(undefined4 *)(param_2 + 200);
*(undefined4 *)(param_1 + 0xd0) = *(undefined4 *)(param_2 + 0xd0);
*(undefined4 *)(param_1 + 0xd4) = *(undefined4 *)(param_2 + 0xd4);
uVar1 = *(uint *)(**(int **)(param_1 + 0x20) + 0x34);
if (*(int *)(param_2 + 0xc4) != *(int *)(**(int **)(param_2 + 0x20) + 0x38)) {
uVar3 = thunk_FUN_005df0f5(uVar1 * 4);
uVar4 = 0;
*(undefined4 *)(param_1 + 0xc4) = uVar3;
if (uVar1 != 0) {
do {
*(undefined4 *)(*(int *)(param_1 + 0xc4) + uVar4 * 4) =
*(undefined4 *)(*(int *)(param_2 + 0xc4) + uVar4 * 4);
(**(code **)(**(int **)(*(int *)(param_1 + 0xc4) + uVar4 * 4) + 0x10))();
uVar4 = uVar4 + 1;
} while (uVar4 < uVar1);
}
return 1;
}
*(undefined4 *)(param_1 + 0xc4) = *(undefined4 *)(**(int **)(param_1 + 0x20) + 0x38);
return 1;
}
// --- FUN_0050e750 at 0x0050E750 (size: 102) ---
void __fastcall FUN_0050e750(int param_1)
{
int *piVar1;
undefined4 *puVar2;
int iVar3;
int local_4;
iVar3 = 0;
local_4 = param_1;
if (0 < *(int *)(**(int **)(param_1 + 0x20) + 0x34)) {
do {
piVar1 = (int *)FUN_00537130(&local_4);
if (*piVar1 != 0) {
puVar2 = (undefined4 *)FUN_00537130(&local_4);
*(undefined4 *)(param_1 + 200) = *puVar2;
return;
}
iVar3 = iVar3 + 1;
} while (iVar3 < *(int *)(**(int **)(param_1 + 0x20) + 0x34));
}
*(undefined4 *)(param_1 + 200) = DAT_00844c6c;
return;
}
// --- FUN_0050e7c0 at 0x0050E7C0 (size: 320) ---
bool FUN_0050e7c0(undefined4 param_1,int *param_2,int *param_3)
{
int iVar1;
undefined4 uVar2;
int *piVar3;
int iVar4;
uint uVar5;
undefined4 *puVar6;
uVar2 = FUN_004220b0(param_1,6);
piVar3 = (int *)FUN_00415430(uVar2);
if (piVar3 == (int *)0x0) {
return false;
}
iVar4 = piVar3[0x2c];
(**(code **)(*piVar3 + 0x14))();
uVar2 = FUN_004220b0(iVar4,0x1a);
iVar4 = FUN_00415430(uVar2);
*param_2 = iVar4;
if (iVar4 == 0) {
puVar6 = (undefined4 *)thunk_FUN_005df0f5(4);
*param_3 = (int)puVar6;
*puVar6 = 0;
uVar2 = FUN_004220b0(param_1,6);
uVar2 = FUN_00415430(uVar2);
*(undefined4 *)*param_3 = uVar2;
}
else {
iVar4 = thunk_FUN_005df0f5(*(int *)(iVar4 + 0x38) << 2);
*param_3 = iVar4;
uVar5 = 0;
if (*(int *)(*param_2 + 0x38) != 0) {
do {
*(undefined4 *)(*param_3 + uVar5 * 4) = 0;
uVar5 = uVar5 + 1;
} while (uVar5 < *(uint *)(*param_2 + 0x38));
}
uVar5 = 0;
if (*(int *)(*param_2 + 0x38) != 0) {
iVar4 = 0;
do {
iVar1 = *(int *)(*(int *)(*param_2 + 0x3c) + iVar4);
if (iVar1 == DAT_00844c6c) {
*(undefined4 *)(*param_3 + uVar5 * 4) = 0;
}
else {
uVar2 = FUN_004220b0(iVar1,6);
uVar2 = FUN_00415430(uVar2);
*(undefined4 *)(*param_3 + uVar5 * 4) = uVar2;
}
uVar5 = uVar5 + 1;
iVar4 = iVar4 + 0x14;
} while (uVar5 < *(uint *)(*param_2 + 0x38));
}
}
iVar4 = *(int *)*param_3;
if (iVar4 == 0) {
FUN_0050e000(param_2,param_3);
}
return iVar4 != 0;
}
// --- FUN_0050e900 at 0x0050E900 (size: 151) ---
undefined4 __thiscall FUN_0050e900(int param_1,int param_2,int param_3)
{
int iVar1;
int iVar2;
int *piVar3;
uint uVar4;
iVar1 = param_3;
if ((param_3 != DAT_00844c6c) &&
((*(int *)(param_1 + 0xc4) != *(int *)(**(int **)(param_1 + 0x20) + 0x38) ||
(iVar2 = FUN_0050e170(), iVar2 != 0)))) {
uVar4 = 0;
if (*(int *)(**(int **)(param_1 + 0x20) + 0x34) != 0) {
do {
piVar3 = (int *)FUN_00537120(&param_3);
if ((*piVar3 == param_2) && (iVar2 = FUN_00537020(iVar1,0), iVar2 == 0)) {
return 0;
}
uVar4 = uVar4 + 1;
} while (uVar4 < *(uint *)(**(int **)(param_1 + 0x20) + 0x34));
}
return 1;
}
return 0;
}
// --- FUN_0050e9a0 at 0x0050E9A0 (size: 147) ---
undefined4 __thiscall FUN_0050e9a0(int param_1,int param_2)
{
int iVar1;
undefined4 uVar2;
if ((param_2 != 0) &&
((*(int *)(param_1 + 0xc4) != *(int *)(**(int **)(param_1 + 0x20) + 0x38) ||
(iVar1 = FUN_0050e170(), iVar1 != 0)))) {
iVar1 = 0;
if (0 < *(int *)(**(int **)(param_1 + 0x20) + 0x34)) {
do {
FUN_00536c60(param_2);
iVar1 = iVar1 + 1;
} while (iVar1 < *(int *)(**(int **)(param_1 + 0x20) + 0x34));
}
if (*(int *)(param_1 + 0xd8) != 0) {
FUN_0053ed10(*(int *)(param_1 + 0xd8));
*(undefined4 *)(param_1 + 0xd8) = 0;
}
uVar2 = FUN_0053ed90(param_2);
*(undefined4 *)(param_1 + 0xd8) = uVar2;
return 1;
}
return 0;
}
// --- FUN_0050ea40 at 0x0050EA40 (size: 44) ---
void __fastcall FUN_0050ea40(int param_1)
{
int iVar1;
if ((*(int **)(param_1 + 0x20) != (int *)0x0) && (iVar1 = **(int **)(param_1 + 0x20), iVar1 != 0))
{
if (*(int *)(param_1 + 0xc0) != *(int *)(iVar1 + 0x30)) {
FUN_00405f70();
}
*(undefined4 *)(param_1 + 0xc0) = 0;
}
return;
}
// --- FUN_0050ea70 at 0x0050EA70 (size: 121) ---
void __fastcall FUN_0050ea70(int param_1)
{
*(undefined4 *)(param_1 + 0x7c) = *(undefined4 *)(param_1 + 0x34);
FUN_00425f10(param_1 + 0x38);
if (*(int *)(param_1 + 0x18) != 1) {
switch(*(int *)(param_1 + 0x18)) {
case 2:
FUN_00536af0(param_1 + 4);
return;
case 3:
FUN_00536780(0,param_1 + 4);
return;
case 4:
FUN_00536780(1,param_1 + 4);
return;
case 5:
FUN_00536780(2,param_1 + 4);
}
}
return;
}
// --- FUN_0050eb00 at 0x0050EB00 (size: 358) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __fastcall FUN_0050eb00(float *param_1)
{
float fVar1;
float fVar2;
int iVar3;
float local_18;
float local_14;
float local_10;
float local_c;
float local_8;
float local_4;
iVar3 = *(int *)param_1[8];
local_c = param_1[9] * *(float *)(iVar3 + 0x7c);
local_8 = param_1[10] * *(float *)(iVar3 + 0x80);
local_10 = param_1[0xb] * *(float *)(iVar3 + 0x84);
local_4 = local_10;
FUN_0050e3f0(&local_18,param_1 + 0xc,&local_c);
fVar2 = _DAT_007c7798;
fVar1 = SQRT(local_18 * local_18 + local_14 * local_14 + local_10 * local_10);
*param_1 = fVar1;
if (fVar1 <= fVar2) {
local_18 = 0.0;
param_1[1] = 0.0;
local_14 = 0.0;
local_10 = 1.0;
param_1[2] = 0.0;
param_1[3] = 1.0;
}
else {
fVar2 = _DAT_007938b0 / fVar1;
local_18 = local_18 * fVar2;
local_14 = local_14 * fVar2;
local_10 = local_10 * fVar2;
param_1[1] = local_18;
param_1[2] = local_14;
param_1[3] = local_10;
local_4 = local_10;
}
if (param_1[4] != 0.0) {
if (param_1[0x38] == 0.0) {
iVar3 = 0;
}
else {
iVar3 = *(int *)((int)param_1[0x38] + 8);
}
if (iVar3 != DAT_00844c08) {
FUN_0051efc0(fVar1 / param_1[0xb],param_1 + 5,param_1 + 6);
goto LAB_0050ec4e;
}
}
param_1[5] = 0.0;
param_1[6] = 1.4013e-45;
LAB_0050ec4e:
if (*(int *)((int)param_1[8] + (int)param_1[5] * 4) != 0) {
FUN_0050ea70();
}
return;
}
// --- FUN_0050ec70 at 0x0050EC70 (size: 130) ---
void __thiscall FUN_0050ec70(float *param_1,float param_2,float *param_3)
{
int iVar1;
*param_1 = param_2;
param_1[1] = *param_3;
param_1[2] = param_3[1];
param_1[3] = param_3[2];
if (param_1[4] != 0.0) {
if (param_1[0x38] == 0.0) {
iVar1 = 0;
}
else {
iVar1 = *(int *)((int)param_1[0x38] + 8);
}
if (iVar1 != DAT_00844c08) {
FUN_0051efc0(param_2 / param_1[0xb],param_1 + 5,param_1 + 6);
goto LAB_0050ecdb;
}
}
param_1[5] = 0.0;
param_1[6] = 1.4013e-45;
LAB_0050ecdb:
if (*(int *)((int)param_1[8] + (int)param_1[5] * 4) != 0) {
FUN_0050ea70();
}
return;
}
// --- FUN_0050ed00 at 0x0050ED00 (size: 50) ---
int FUN_0050ed00(undefined4 param_1)
{
int iVar1;
iVar1 = FUN_005df0f5(0xe8);
if (iVar1 != 0) {
iVar1 = FUN_0050e550();
if (iVar1 != 0) {
FUN_0050e640(param_1);
}
return iVar1;
}
return 0;
}
// --- FUN_0050ed40 at 0x0050ED40 (size: 105) ---
void __fastcall FUN_0050ed40(int param_1)
{
int iVar1;
if (*(int **)(param_1 + 0xd8) != (int *)0x0) {
(**(code **)(**(int **)(param_1 + 0xd8) + 0x14))();
*(undefined4 *)(param_1 + 0xd8) = 0;
}
if ((*(int **)(param_1 + 0x20) != (int *)0x0) && (iVar1 = **(int **)(param_1 + 0x20), iVar1 != 0))
{
if (*(int *)(param_1 + 0xc0) != *(int *)(iVar1 + 0x30)) {
FUN_00405f70();
}
*(undefined4 *)(param_1 + 0xc0) = 0;
}
FUN_0050e200();
FUN_0050e000(param_1 + 0x10,param_1 + 0x20);
*(undefined ***)(param_1 + 0x78) = &PTR_FUN_0079385c;
*(undefined ***)(param_1 + 0x30) = &PTR_FUN_0079385c;
return;
}
// --- FUN_0050edb0 at 0x0050EDB0 (size: 198) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_0050edb0(int param_1,undefined4 param_2,int *param_3)
{
int *piVar1;
int iVar2;
float10 fVar3;
FUN_0050e200();
piVar1 = (int *)(param_1 + 0x20);
FUN_0050e000((undefined4 *)(param_1 + 0x10),piVar1);
*(undefined4 *)(param_1 + 0x10) = param_2;
*piVar1 = (int)param_3;
*(undefined4 *)(param_1 + 0xc4) = *(undefined4 *)(*param_3 + 0x38);
FUN_0050e750();
if ((((int *)*piVar1 == (int *)0x0) || (iVar2 = *(int *)*piVar1, iVar2 == 0)) ||
(*(int *)(iVar2 + 0x30) == 0)) {
fVar3 = (float10)DAT_00796344;
}
else {
fVar3 = (float10)FUN_0053a450();
}
*(float *)(param_1 + 0xcc) = (float)fVar3;
if ((((int *)*piVar1 == (int *)0x0) || (iVar2 = *(int *)*piVar1, iVar2 == 0)) ||
(*(int *)(iVar2 + 0x30) == 0)) {
fVar3 = (float10)_DAT_007938b0;
}
else {
fVar3 = (float10)FUN_0069f540();
}
*(float *)(param_1 + 0xd0) = (float)fVar3;
if ((((int *)*piVar1 == (int *)0x0) || (iVar2 = *(int *)*piVar1, iVar2 == 0)) ||
(*(int *)(iVar2 + 0x30) == 0)) {
fVar3 = (float10)DAT_00796344;
}
else {
fVar3 = (float10)FUN_0053a480();
}
*(float *)(param_1 + 0xd4) = (float)fVar3;
if (*(int *)(param_1 + 0xd8) != 0) {
FUN_0050e9a0(*(int *)(param_1 + 0xd8));
}
return;
}
// --- FUN_0050ee80 at 0x0050EE80 (size: 71) ---
undefined4 __fastcall FUN_0050ee80(int param_1)
{
int iVar1;
if (*(int *)(param_1 + 0xd8) != 0) {
FUN_0050e9a0(*(int *)(param_1 + 0xd8));
}
iVar1 = 0;
if (0 < *(int *)(**(int **)(param_1 + 0x20) + 0x34)) {
do {
FUN_00537140(0);
iVar1 = iVar1 + 1;
} while (iVar1 < *(int *)(**(int **)(param_1 + 0x20) + 0x34));
}
return 1;
}
// --- FUN_0050eed0 at 0x0050EED0 (size: 158) ---
void __thiscall FUN_0050eed0(int param_1,float param_2,float param_3)
{
char cVar1;
int iVar2;
if ((param_2 != *(float *)(param_1 + 0xd4)) || (param_3 != *(float *)(param_1 + 0xd0))) {
*(float *)(param_1 + 0xd0) = param_3;
*(float *)(param_1 + 0xd4) = param_2;
cVar1 = FUN_0050e4b0();
if (cVar1 == '\0') {
iVar2 = FUN_0050e100();
if (iVar2 != 0) {
FUN_0053a460(param_2);
FUN_0053a490(param_3);
}
}
else if ((*(int **)(param_1 + 0x20) != (int *)0x0) &&
(iVar2 = **(int **)(param_1 + 0x20), iVar2 != 0)) {
if (*(int *)(param_1 + 0xc0) != *(int *)(iVar2 + 0x30)) {
FUN_00405f70();
}
*(undefined4 *)(param_1 + 0xc0) = 0;
return;
}
}
return;
}
// --- FUN_0050ef70 at 0x0050EF70 (size: 199) ---
void __fastcall FUN_0050ef70(int param_1)
{
int iVar1;
int *piVar2;
float10 fVar3;
undefined4 local_8;
undefined4 local_4;
if (((*(int **)(param_1 + 0x20) == (int *)0x0) || (iVar1 = **(int **)(param_1 + 0x20), iVar1 == 0)
) || (*(int *)(iVar1 + 0x30) == 0)) {
fVar3 = (float10)DAT_00796344;
}
else {
fVar3 = (float10)FUN_0053a450();
}
piVar2 = *(int **)(param_1 + 0x20);
if (fVar3 != (float10)*(float *)(param_1 + 0xcc)) {
if (((piVar2 == (int *)0x0) || (*piVar2 == 0)) || (*(int *)(*piVar2 + 0x30) == 0)) {
local_4 = 0.0;
}
else {
fVar3 = (float10)FUN_0053a480();
local_4 = (float)fVar3;
}
if (((*(int **)(param_1 + 0x20) == (int *)0x0) ||
(iVar1 = **(int **)(param_1 + 0x20), iVar1 == 0)) || (*(int *)(iVar1 + 0x30) == 0)) {
local_8 = 1.0;
}
else {
fVar3 = (float10)FUN_0069f540();
local_8 = (float)fVar3;
}
FUN_0050eed0(local_4,local_8);
return;
}
if ((piVar2 != (int *)0x0) && (*piVar2 != 0)) {
if (*(int *)(param_1 + 0xc0) != *(int *)(*piVar2 + 0x30)) {
FUN_00405f70();
}
*(undefined4 *)(param_1 + 0xc0) = 0;
}
return;
}
// --- FUN_0050f040 at 0x0050F040 (size: 113) ---
void __thiscall FUN_0050f040(int param_1,float param_2)
{
char cVar1;
int iVar2;
if (param_2 != *(float *)(param_1 + 0xd0)) {
*(float *)(param_1 + 0xd0) = param_2;
cVar1 = FUN_0050e4b0();
if (cVar1 == '\0') {
iVar2 = FUN_0050e100();
if (iVar2 != 0) {
FUN_0053a490(param_2);
}
}
else if ((*(int **)(param_1 + 0x20) != (int *)0x0) &&
(iVar2 = **(int **)(param_1 + 0x20), iVar2 != 0)) {
if (*(int *)(param_1 + 0xc0) != *(int *)(iVar2 + 0x30)) {
FUN_00405f70();
}
*(undefined4 *)(param_1 + 0xc0) = 0;
return;
}
}
return;
}
// --- FUN_0050f0c0 at 0x0050F0C0 (size: 113) ---
void __thiscall FUN_0050f0c0(int param_1,float param_2)
{
char cVar1;
int iVar2;
if (param_2 != *(float *)(param_1 + 0xd4)) {
*(float *)(param_1 + 0xd4) = param_2;
cVar1 = FUN_0050e4b0();
if (cVar1 == '\0') {
iVar2 = FUN_0050e100();
if (iVar2 != 0) {
FUN_0053a460(param_2);
}
}
else if ((*(int **)(param_1 + 0x20) != (int *)0x0) &&
(iVar2 = **(int **)(param_1 + 0x20), iVar2 != 0)) {
if (*(int *)(param_1 + 0xc0) != *(int *)(iVar2 + 0x30)) {
FUN_00405f70();
}
*(undefined4 *)(param_1 + 0xc0) = 0;
return;
}
}
return;
}
// --- FUN_0050f140 at 0x0050F140 (size: 139) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_0050f140(int param_1,float param_2)
{
char cVar1;
int iVar2;
if ((*(int *)(param_1 + 0xe0) == 0) ||
((*(uint *)(*(int *)(param_1 + 0xe0) + 0xa8) & 0x100000) == 0)) {
if (param_2 == _DAT_007938b0) {
*(uint *)(param_1 + 0x1c) = *(uint *)(param_1 + 0x1c) | 1;
return;
}
*(uint *)(param_1 + 0x1c) = *(uint *)(param_1 + 0x1c) & 0xfffffffe;
if (*(float *)(param_1 + 0xcc) != param_2) {
*(float *)(param_1 + 0xcc) = param_2;
cVar1 = FUN_0050e4b0();
if (cVar1 != '\0') {
FUN_0050ea40();
return;
}
iVar2 = FUN_0050e100();
if (iVar2 != 0) {
FUN_0053a430(param_2);
}
}
}
return;
}
// --- FUN_0050f1d0 at 0x0050F1D0 (size: 83) ---
undefined4 FUN_0050f1d0(int param_1)
{
int iVar1;
undefined4 local_4;
iVar1 = param_1;
if (param_1 != DAT_00844c6c) {
param_1 = 0;
local_4 = 0;
iVar1 = FUN_0050e7c0(iVar1,&local_4,&param_1);
if (iVar1 != 0) {
FUN_0050edb0(local_4,param_1);
return 1;
}
}
return 0;
}
// --- FUN_0050f230 at 0x0050F230 (size: 73) ---
void * FUN_0050f230(undefined4 param_1)
{
int iVar1;
void *pvVar2;
iVar1 = FUN_005df0f5(0xe8);
if (iVar1 != 0) {
pvVar2 = (void *)FUN_0050e550();
if (pvVar2 != (void *)0x0) {
iVar1 = FUN_0050f1d0(param_1);
if (iVar1 == 0) {
FUN_0050ed40();
operator_delete(pvVar2);
pvVar2 = (void *)0x0;
}
return pvVar2;
}
}
return (void *)0x0;
}
// --- FUN_0050f280 at 0x0050F280 (size: 68) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 __fastcall FUN_0050f280(float *param_1)
{
if (((ABS(*param_1) < _DAT_007c78bc) && (ABS(param_1[1]) < _DAT_007c78bc)) &&
(ABS(param_1[2]) < _DAT_007c78bc)) {
return 1;
}
return 0;
}
// --- FUN_0050f2d0 at 0x0050F2D0 (size: 71) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
undefined4 FUN_0050f2d0(float *param_1,float param_2)
{
if ((((param_2 <= *param_1) && (param_2 <= param_1[1])) && (*param_1 < _DAT_00844d8c - param_2))
&& (param_1[1] < _DAT_00844d8c - param_2)) {
return 1;
}
return 0;
}
// --- FUN_0050f320 at 0x0050F320 (size: 132) ---
void __thiscall FUN_0050f320(int param_1,undefined4 param_2,undefined4 *param_3,undefined4 param_4)
{
*(undefined4 *)(param_1 + 0x270) = 1;
*(undefined4 *)(param_1 + 0x274) = *param_3;
*(undefined4 *)(param_1 + 0x278) = param_3[1];
*(undefined4 *)(param_1 + 0x27c) = param_3[2];
*(undefined4 *)(param_1 + 0x280) = param_3[3];
*(undefined4 *)(param_1 + 0x284) = param_4;
*(undefined4 *)(param_1 + 0x2a0) = param_2;
*(undefined4 *)(param_1 + 0x288) = 1;
*(undefined4 *)(param_1 + 0x28c) = *param_3;
*(undefined4 *)(param_1 + 0x290) = param_3[1];
*(undefined4 *)(param_1 + 0x294) = param_3[2];
*(undefined4 *)(param_1 + 0x298) = param_3[3];
*(undefined4 *)(param_1 + 0x2a4) = param_4;
*(undefined4 *)(param_1 + 0x29c) = param_2;
return;
}
// --- FUN_0050f3b0 at 0x0050F3B0 (size: 75) ---
void __thiscall FUN_0050f3b0(int param_1,undefined4 param_2,undefined4 *param_3,undefined4 param_4)
{
*(undefined4 *)(param_1 + 0x270) = 1;
*(undefined4 *)(param_1 + 0x274) = *param_3;
*(undefined4 *)(param_1 + 0x278) = param_3[1];
*(undefined4 *)(param_1 + 0x27c) = param_3[2];
*(undefined4 *)(param_1 + 0x280) = param_3[3];
*(undefined4 *)(param_1 + 0x284) = param_4;
*(undefined4 *)(param_1 + 0x29c) = param_2;
return;
}
// --- FUN_0050f400 at 0x0050F400 (size: 38) ---
bool __thiscall FUN_0050f400(int param_1,undefined4 param_2,undefined4 param_3)
{
int iVar1;
iVar1 = FUN_0051a0d0(param_1,param_2,param_3);
*(int *)(param_1 + 0x10) = iVar1;
return iVar1 != 0;
}
// --- FUN_0050f430 at 0x0050F430 (size: 39) ---
undefined4 * __thiscall FUN_0050f430(int param_1,undefined4 *param_2)
{
if (*(int *)(param_1 + 0x10) != 0) {
FUN_005195e0(param_2);
return param_2;
}
*param_2 = DAT_00844d94;
return param_2;
}
// --- FUN_0050f460 at 0x0050F460 (size: 39) ---
undefined4 * __thiscall FUN_0050f460(int param_1,undefined4 *param_2)
{
if (*(int *)(param_1 + 0x10) != 0) {
FUN_005195f0(param_2);
return param_2;
}
*param_2 = DAT_00844d94;
return param_2;
}
// --- FUN_0050f490 at 0x0050F490 (size: 19) ---
float10 __fastcall FUN_0050f490(int param_1)
{
float10 fVar1;
if (*(int *)(param_1 + 0x10) != 0) {
fVar1 = (float10)FUN_00518bd0();
return fVar1;
}
return (float10)DAT_00796344;
}
// --- FUN_0050f4b0 at 0x0050F4B0 (size: 19) ---
float10 __fastcall FUN_0050f4b0(int param_1)
{
float10 fVar1;
if (*(int *)(param_1 + 0x10) != 0) {
fVar1 = (float10)FUN_00518be0();
return fVar1;
}
return (float10)DAT_00796344;
}
// --- FUN_0050f4d0 at 0x0050F4D0 (size: 19) ---
float10 __fastcall FUN_0050f4d0(int param_1)
{
float10 fVar1;
if (*(int *)(param_1 + 0x10) != 0) {
fVar1 = (float10)FUN_00518c00();
return fVar1;
}
return (float10)DAT_00796344;
}
// --- FUN_0050f4f0 at 0x0050F4F0 (size: 19) ---
float10 __fastcall FUN_0050f4f0(int param_1)
{
float10 fVar1;
if (*(int *)(param_1 + 0x10) != 0) {
fVar1 = (float10)FUN_00518c20();
return fVar1;
}
return (float10)DAT_00796344;
}
// --- FUN_0050f510 at 0x0050F510 (size: 17) ---
undefined4 __fastcall FUN_0050f510(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 0x10) != 0) {
uVar1 = FUN_005196b0();
return uVar1;
}
return 0;
}
// --- FUN_0050f530 at 0x0050F530 (size: 13) ---
void __fastcall FUN_0050f530(int param_1)
{
if (*(int *)(param_1 + 0x10) != 0) {
FUN_00518840();
return;
}
return;
}
// --- FUN_0050f540 at 0x0050F540 (size: 20) ---
undefined4 __fastcall FUN_0050f540(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 0x10) != 0) {
uVar1 = FUN_00519280();
return uVar1;
}
return 0x47;
}
// --- FUN_0050f560 at 0x0050F560 (size: 20) ---
undefined4 __fastcall FUN_0050f560(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 0x10) != 0) {
uVar1 = FUN_00519320();
return uVar1;
}
return 0x47;
}
// --- FUN_0050f580 at 0x0050F580 (size: 28) ---
undefined4 __fastcall FUN_0050f580(int param_1)
{
int iVar1;
if (*(int *)(param_1 + 0xc4) != 0) {
iVar1 = FUN_00524e80();
if (iVar1 != 0) {
return 1;
}
}
return 0;
}
// --- FUN_0050f5a0 at 0x0050F5A0 (size: 13) ---
void __fastcall FUN_0050f5a0(int param_1)
{
if (*(int *)(param_1 + 0x10) != 0) {
FUN_005193c0();
return;
}
return;
}
// --- FUN_0050f5b0 at 0x0050F5B0 (size: 16) ---
void __fastcall FUN_0050f5b0(int param_1)
{
if (*(int *)(param_1 + 200) != 0) {
FUN_00555e00();
return;
}
return;
}
// --- FUN_0050f5c0 at 0x0050F5C0 (size: 18) ---
undefined4 __fastcall FUN_0050f5c0(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 200) != 0) {
uVar1 = FUN_00555e90();
return uVar1;
}
return 0;
}
// --- FUN_0050f5e0 at 0x0050F5E0 (size: 28) ---
undefined4 __fastcall FUN_0050f5e0(int param_1)
{
int iVar1;
if (*(int *)(param_1 + 0xc4) != 0) {
iVar1 = FUN_00524e60();
if (iVar1 != 0) {
return 1;
}
}
return 0;
}
// --- FUN_0050f600 at 0x0050F600 (size: 7) ---
undefined4 __fastcall FUN_0050f600(int param_1)
{
return *(undefined4 *)(param_1 + 0xcc);
}
// --- FUN_0050f610 at 0x0050F610 (size: 16) ---
void __fastcall FUN_0050f610(int param_1)
{
if (*(int *)(param_1 + 200) != 0) {
FUN_00555e40();
return;
}
return;
}
// --- FUN_0050f620 at 0x0050F620 (size: 18) ---
undefined4 __fastcall FUN_0050f620(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 200) != 0) {
uVar1 = FUN_00555fd0();
return uVar1;
}
return 0;
}
// --- FUN_0050f640 at 0x0050F640 (size: 68) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
float10 __fastcall FUN_0050f640(int param_1)
{
if (param_1 != DAT_00844d68) {
if ((*(uint *)(param_1 + 0x4c) & 0xffff) < 0x100) {
return (float10)_DAT_007c7854;
}
return (float10)_DAT_007c7858;
}
if ((*(uint *)(param_1 + 0x4c) & 0xffff) < 0x100) {
return (float10)_DAT_007c784c;
}
return (float10)_DAT_007c7850;
}
// --- FUN_0050f690 at 0x0050F690 (size: 68) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
float10 __fastcall FUN_0050f690(int param_1)
{
if (param_1 != DAT_00844d68) {
if ((*(uint *)(param_1 + 0x4c) & 0xffff) < 0x100) {
return (float10)_DAT_007c7864;
}
return (float10)_DAT_007c7868;
}
if ((*(uint *)(param_1 + 0x4c) & 0xffff) < 0x100) {
return (float10)_DAT_007c785c;
}
return (float10)_DAT_007c7860;
}
// --- FUN_0050f6e0 at 0x0050F6E0 (size: 68) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
float10 __fastcall FUN_0050f6e0(int param_1)
{
if (param_1 != DAT_00844d68) {
if ((*(uint *)(param_1 + 0x4c) & 0xffff) < 0x100) {
return (float10)_DAT_007c7874;
}
return (float10)_DAT_007c7878;
}
if ((*(uint *)(param_1 + 0x4c) & 0xffff) < 0x100) {
return (float10)_DAT_007c786c;
}
return (float10)_DAT_007c7870;
}
// --- FUN_0050f730 at 0x0050F730 (size: 18) ---
undefined4 __fastcall FUN_0050f730(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 200) != 0) {
uVar1 = FUN_00555ee0();
return uVar1;
}
return 0;
}
// --- FUN_0050f750 at 0x0050F750 (size: 173) ---
undefined4 __thiscall
FUN_0050f750(int param_1,undefined4 param_2,float param_3,int param_4,float param_5)
{
undefined4 uVar1;
float10 fVar2;
undefined4 local_8;
undefined4 local_4;
if (((*(int *)(param_1 + 0x40) == 0) && ((*(uint *)(param_1 + 0xa8) & 0x10) == 0)) &&
((*(uint *)(param_1 + 0xa8) & 0x200000) == 0)) {
if (*(int *)(param_1 + 0x10) == 0) {
local_8 = 0.0;
}
else {
fVar2 = (float10)FUN_00518be0();
local_8 = (float)fVar2;
}
if (*(int *)(param_1 + 0x10) == 0) {
local_4 = 0.0;
}
else {
fVar2 = (float10)FUN_00518bd0();
local_4 = (float)fVar2;
}
uVar1 = FUN_005377f0(param_1 + 0x48,local_4,local_8,param_2,param_4 + 4,param_4 + 0xc,
param_3 * *(float *)(param_4 + 0x14) + param_5,
param_3 * *(float *)(param_4 + 0x18));
return uVar1;
}
return 0;
}
// --- FUN_0050f800 at 0x0050F800 (size: 85) ---
void __thiscall
FUN_0050f800(int param_1,undefined4 param_2,undefined4 param_3,undefined4 param_4,undefined4 param_5
,undefined4 param_6)
{
int iVar1;
undefined4 uVar2;
if (*(int *)(param_1 + 0x124) == 0) {
iVar1 = FUN_005df0f5(0x18);
if (iVar1 == 0) {
uVar2 = 0;
}
else {
uVar2 = FUN_0051af50(param_1);
}
*(undefined4 *)(param_1 + 0x124) = uVar2;
}
FUN_0051b760(param_2,param_3,param_4,param_5,param_6);
return;
}
// --- FUN_0050f860 at 0x0050F860 (size: 16) ---
void __fastcall FUN_0050f860(int param_1)
{
if (*(int *)(param_1 + 0x124) != 0) {
FUN_0051b310();
return;
}
return;
}
// --- FUN_0050f870 at 0x0050F870 (size: 28) ---
void __thiscall FUN_0050f870(int param_1,undefined4 param_2,undefined4 param_3)
{
if (*(int *)(param_1 + 0x124) != 0) {
FUN_0051b040(param_2,param_3);
}
return;
}
// --- FUN_0050f890 at 0x0050F890 (size: 28) ---
float10 __fastcall FUN_0050f890(int param_1)
{
int iVar1;
if ((*(int *)(param_1 + 0x124) != 0) &&
(iVar1 = *(int *)(*(int *)(param_1 + 0x124) + 4), iVar1 != 0)) {
return (float10)*(double *)(iVar1 + 0x10);
}
return (float10)DAT_00796344;
}
// --- FUN_0050f8b0 at 0x0050F8B0 (size: 18) ---
void __fastcall FUN_0050f8b0(int param_1)
{
if (*(int *)(param_1 + 0x124) != 0) {
FUN_0051b460();
return;
}
return;
}
// --- FUN_0050f8d0 at 0x0050F8D0 (size: 80) ---
void __thiscall FUN_0050f8d0(int param_1,undefined4 param_2,undefined4 param_3,float param_4)
{
int iVar1;
undefined4 uVar2;
if (*(int *)(param_1 + 0x124) == 0) {
iVar1 = FUN_005df0f5();
if (iVar1 == 0) {
uVar2 = 0;
}
else {
uVar2 = FUN_0051af50();
}
*(undefined4 *)(param_1 + 0x124) = uVar2;
}
FUN_0051b360(param_2,param_3,(double)param_4);
return;
}
// --- FUN_0050f920 at 0x0050F920 (size: 20) ---
undefined4 __fastcall FUN_0050f920(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 0x124) != 0) {
uVar1 = FUN_0051b8c0();
return uVar1;
}
return 0;
}
// --- FUN_0050f940 at 0x0050F940 (size: 479) ---
/* WARNING: Globals starting with '_' overlap smaller symbols at the same address */
void __thiscall FUN_0050f940(int param_1,undefined4 param_2,float param_3)
{
float fVar1;
float10 fVar2;
if ((*(byte *)(param_1 + 0xac) & 2) != 0) {
if ((*(uint *)(param_1 + 0xa8) & 0x800000) == 0) {
fVar1 = *(float *)(param_1 + 0x130) * *(float *)(param_1 + 0xe0) +
*(float *)(param_1 + 0x134) * *(float *)(param_1 + 0xe4) +
*(float *)(param_1 + 0x138) * *(float *)(param_1 + 0xe8);
if (fVar1 < _DAT_007c78a0) {
*(float *)(param_1 + 0xe0) =
*(float *)(param_1 + 0xe0) - fVar1 * *(float *)(param_1 + 0x130);
*(float *)(param_1 + 0xe4) =
*(float *)(param_1 + 0xe4) - fVar1 * *(float *)(param_1 + 0x134);
*(float *)(param_1 + 0xe8) =
*(float *)(param_1 + 0xe8) - fVar1 * *(float *)(param_1 + 0x138);
goto LAB_0050fad8;
}
}
else {
fVar1 = *(float *)(param_1 + 0xe0) * *(float *)(param_1 + 0x130) +
*(float *)(param_1 + 0xe4) * *(float *)(param_1 + 0x134) +
*(float *)(param_1 + 0xe8) * *(float *)(param_1 + 0x138);
if (fVar1 < _DAT_007c78a0) {
*(float *)(param_1 + 0xe0) =
*(float *)(param_1 + 0xe0) - fVar1 * *(float *)(param_1 + 0x130);
*(float *)(param_1 + 0xe4) =
*(float *)(param_1 + 0xe4) - fVar1 * *(float *)(param_1 + 0x134);
*(float *)(param_1 + 0xe8) =
*(float *)(param_1 + 0xe8) - fVar1 * *(float *)(param_1 + 0x138);
if (((float)_DAT_007c78d8 <= param_3) && ((float)_DAT_007c78d0 <= param_3)) {
fcos((float10)_DAT_007c78c8);
}
LAB_0050fad8:
fVar2 = (float10)_CIpow();
*(float *)(param_1 + 0xe0) = (float)(fVar2 * (float10)*(float *)(param_1 + 0xe0));
*(float *)(param_1 + 0xe4) = (float)(fVar2 * (float10)*(float *)(param_1 + 0xe4));
*(float *)(param_1 + 0xe8) = (float)(fVar2 * (float10)*(float *)(param_1 + 0xe8));
return;
}
}
}
return;
}
// --- FUN_0050fb20 at 0x0050FB20 (size: 737) ---
int __thiscall FUN_0050fb20(int param_1,uint param_2)
{
undefined4 uVar1;
int iVar2;
int iVar3;
int iVar4;
uint uVar5;
uint uVar6;
bool bVar7;
int local_c;
int iStack_8;
iVar2 = param_2;
if ((((*(uint *)(param_1 + 0xa8) & 4) != 0) && ((*(uint *)(param_1 + 0xa8) & 0x10) != 0)) ||
((*(int **)(param_1 + 300) != (int *)0x0 &&
(((*(byte *)(param_2 + 4) & 4) != 0 &&
(iVar3 = (**(code **)(**(int **)(param_1 + 300) + 0x2c))(), iVar3 != 0)))))) {
return 1;
}
if (((*(uint *)(param_1 + 0xa8) & 4) == 0) &&
((*(int *)(param_2 + 0x14) == 0 || ((*(uint *)(param_1 + 0xa8) & 1) != 0)))) {
local_c = 0;
}
else {
local_c = 1;
if (*(int *)(param_2 + 0x178) != 0) {
return 1;
}
}
*(int *)(param_2 + 0x1cc) = local_c;
if ((((((*(int **)(param_1 + 300) == (int *)0x0) ||
(iVar3 = (**(code **)(**(int **)(param_1 + 300) + 0x10))(), iVar3 == 0)) ||
((*(uint *)(param_2 + 4) & 0x100) == 0)) ||
((bVar7 = true, (char)*(uint *)(param_2 + 4) < '\0' ||
(iVar3 = (**(code **)(**(int **)(param_1 + 300) + 0x28))(), iVar3 != 0)))) ||
(((*(uint *)(param_2 + 4) & 0x800) != 0 &&
(iVar3 = (**(code **)(**(int **)(param_1 + 300) + 0x20))(), iVar3 != 0)))) ||
(((*(uint *)(param_2 + 4) & 0x1000) != 0 &&
(iVar3 = (**(code **)(**(int **)(param_1 + 300) + 0x24))(), iVar3 != 0)))) {
bVar7 = false;
}
iVar3 = 1;
iStack_8 = 0;
if (((*(byte *)(param_1 + 0xa8) & 0x40) != 0) ||
((*(int **)(param_1 + 300) != (int *)0x0 &&
(iVar4 = (**(code **)(**(int **)(param_1 + 300) + 0x2c))(), iVar4 != 0)))) {
iStack_8 = 1;
}
if ((((*(uint *)(param_1 + 0xa8) & 0x10000) == 0) || (bVar7)) ||
(iVar4 = FUN_0050d980(param_1), iVar4 != 0)) {
if (((*(int *)(param_1 + 0x10) == 0) || (iVar4 = FUN_00518bb0(), iVar4 == 0)) ||
((bVar7 || (iVar4 = FUN_0050d980(param_1), iVar4 != 0)))) {
if (((*(int *)(param_1 + 0x10) != 0) && (iVar4 = FUN_00518b90(), iVar4 != 0)) &&
((!bVar7 && (iVar4 = FUN_0050d980(param_1), iVar4 == 0)))) {
for (param_2 = 0;
(*(int *)(param_1 + 0x10) != 0 && (uVar6 = FUN_00518b90(), param_2 < uVar6));
param_2 = param_2 + 1) {
uVar1 = *(undefined4 *)(param_1 + 0x114);
if (*(int *)(param_1 + 0x10) != 0) {
FUN_00518ba0();
}
iVar3 = FUN_00538d10(param_1 + 0x48,uVar1,iVar2,iStack_8);
if (iVar3 != 1) goto LAB_0050fd80;
}
}
}
else {
for (uVar6 = 0; (*(int *)(param_1 + 0x10) != 0 && (uVar5 = FUN_00518bb0(), uVar6 < uVar5));
uVar6 = uVar6 + 1) {
uVar1 = *(undefined4 *)(param_1 + 0x114);
if (*(int *)(param_1 + 0x10) != 0) {
FUN_00518bc0();
}
iVar3 = FUN_0053c650(param_1 + 0x48,uVar1,param_2);
if (iVar3 != 1) goto LAB_0050fd80;
}
}
}
else if ((*(int *)(param_1 + 0x10) != 0) && (iVar3 = FUN_00518cb0(param_2), iVar3 != 1)) {
LAB_0050fd80:
if (*(int *)(iVar2 + 0x178) == 0) {
if ((*(byte *)(param_1 + 0xa8) & 1) == 0) {
if ((local_c == 0) && ((iStack_8 == 0 || ((*(uint *)(iVar2 + 4) & 0x400) == 0)))) {
FUN_006b5d60(param_1,iVar3);
}
else {
iVar3 = 1;
*(undefined4 *)(iVar2 + 0x2b8) = 0;
FUN_006b5d60(param_1,1);
}
}
else if ((*(byte *)(iVar2 + 4) & 1) == 0) {
*(undefined4 *)(iVar2 + 0x2ec) = 1;
}
}
}
*(undefined4 *)(iVar2 + 0x1cc) = 0;
return iVar3;
}
// --- FUN_0050fe10 at 0x0050FE10 (size: 22) ---
void __thiscall FUN_0050fe10(int param_1,undefined4 param_2)
{
*(undefined4 *)(param_1 + 0x24) = param_2;
if (*(int *)(param_1 + 0x10) != 0) {
FUN_00518dc0();
return;
}
return;
}
// --- FUN_0050fe30 at 0x0050FE30 (size: 80) ---
void __thiscall
FUN_0050fe30(int param_1,undefined4 param_2,undefined4 param_3,undefined4 param_4,undefined4 param_5
)
{
int iVar1;
undefined4 uVar2;
if (*(int *)(param_1 + 0x128) == 0) {
iVar1 = FUN_005df0f5(0xc);
if (iVar1 == 0) {
uVar2 = 0;
}
else {
uVar2 = FUN_0051c100();
}
*(undefined4 *)(param_1 + 0x128) = uVar2;
}
FUN_0051c1f0(param_1,param_2,param_3,param_4,param_5);
return;
}
// --- FUN_0050fe80 at 0x0050FE80 (size: 80) ---
void __thiscall
FUN_0050fe80(int param_1,undefined4 param_2,undefined4 param_3,undefined4 param_4,undefined4 param_5
)
{
int iVar1;
undefined4 uVar2;
if (*(int *)(param_1 + 0x128) == 0) {
iVar1 = FUN_005df0f5(0xc);
if (iVar1 == 0) {
uVar2 = 0;
}
else {
uVar2 = FUN_0051c100();
}
*(undefined4 *)(param_1 + 0x128) = uVar2;
}
FUN_0051c3d0(param_1,param_2,param_3,param_4,param_5);
return;
}
// --- FUN_0050fed0 at 0x0050FED0 (size: 20) ---
undefined4 __fastcall FUN_0050fed0(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 0x128) != 0) {
uVar1 = FUN_0051c2a0();
return uVar1;
}
return 0;
}
// --- FUN_0050fef0 at 0x0050FEF0 (size: 20) ---
undefined4 __fastcall FUN_0050fef0(int param_1)
{
undefined4 uVar1;
if (*(int *)(param_1 + 0x128) != 0) {
uVar1 = FUN_0051c2e0();
return uVar1;
}
return 0;
}
// --- FUN_0050ff30 at 0x0050FF30 (size: 36) ---
bool __thiscall FUN_0050ff30(int param_1,undefined4 param_2,undefined4 param_3)
{
bool bVar1;
bVar1 = *(int *)(param_1 + 0x28) != 0;
if (bVar1) {
FUN_00551700(param_2,param_1,param_3);
}
return bVar1;
}
// --- FUN_0050ff60 at 0x0050FF60 (size: 24) ---
undefined4 FUN_0050ff60(undefined4 param_1)
{
undefined4 uVar1;
if (DAT_00844d64 != 0) {
uVar1 = FUN_00508890(param_1);
return uVar1;
}
return 0;
}
// --- FUN_0050ff80 at 0x0050FF80 (size: 10) ---
void FUN_0050ff80(undefined4 param_1)
{
DAT_00844d64 = param_1;
return;
}
// --- FUN_0050ff90 at 0x0050FF90 (size: 10) ---
void FUN_0050ff90(undefined4 param_1)
{
DAT_00844d68 = param_1;
return;
}
// --- FUN_0050ffa0 at 0x0050FFA0 (size: 32) ---
void __thiscall FUN_0050ffa0(int param_1,undefined4 param_2)
{
*(undefined4 *)(param_1 + 300) = param_2;
if (*(int *)(param_1 + 0xc4) != 0) {
FUN_00524c20();
return;
}
return;
}
// --- FUN_0050ffc0 at 0x0050FFC0 (size: 37) ---
void __thiscall FUN_0050ffc0(int param_1,undefined4 param_2)
{
*(undefined4 *)(param_1 + 0x4c) = param_2;
if (((*(uint *)(param_1 + 0xa8) & 0x1000) == 0) && (*(int *)(param_1 + 0x10) != 0)) {
FUN_00518900();
return;
}
return;
}
// --- FUN_0050fff0 at 0x0050FFF0 (size: 15) ---
void __fastcall FUN_0050fff0(int param_1)
{
if (*(int *)(param_1 + 0x10) != 0) {
FUN_00518930();
return;
}
return;
}