The first commit

This commit is contained in:
Banjo Kazooie
2022-07-15 17:09:41 -05:00
commit dd13d34074
1087 changed files with 391897 additions and 0 deletions

266
src/core2/code_76D90.c Normal file
View File

@@ -0,0 +1,266 @@
#include <ultra64.h>
#include "functions.h"
#include "variables.h"
#define _76D90_MAX(s,t) ((s < t)? t : s)
#define _76D90_MIN(s,t) ((s > t)? t : s)
f32 time_getDelta(void);
f32 func_802FDE60(f32);
void timedFunc_set_1(f32, void (*)(s32), s32);
void timedFunc_set_2(f32, void (*)(s32,s32), s32, s32);
void item_inc(s32);
void func_80314AC8(s32);
void item_set(s32, s32);
f32 func_802FB0E4(s32);
extern void *D_8036A010;
extern void *D_8036A014;
extern f32 D_8036A018[];
extern Gfx D_8036A030[];
extern s32 D_803815C0;
extern s32 D_803815C4;
extern f32 D_803815C8;
extern f32 D_803815CC;
extern f32 D_803815D0;
extern f32 D_803815D4;
extern f32 D_803815D8;
extern f32 D_803815DC;
extern f32 D_803815E0;
extern s32 D_803815E4;
extern s32 D_803815E8;
extern s32 D_803815EC;
extern struct8s D_803815F0;
extern s32 D_80381610;
/* rodata
!!! NOTE the second half of .rodata is already defined as .rodata
COMBINE IN subyaml/core2.us.v10.yaml
*/
extern f64 D_803773B0;
extern f64 D_803773B8;
extern f64 D_803773C0;
extern f64 D_803773C8;
void func_802FDD20(void) {
s32 phi_v1;
D_803815CC = -272.0f;
D_803815C8 = 1.0f;
D_803815C0 = 0;
D_803815D8 = 60 * ((item_getCount(0x13) <= 0)? 0: item_getCount(0x13)-1);
D_803815DC = 0.0f;
D_803815E0 = 1.0f;
D_803815E8 = 0x50;
}
void func_802FDDC4(s32 arg0, struct8s *arg1){
if(D_8036A010){
func_8033BD4C(D_8036A010);
D_8036A010 = NULL;
}
if(D_8036A014){
func_8033BD4C(D_8036A014);
D_8036A014 = NULL;
}
D_803815E8 = 0x50;
}
struct8s *func_802FDE2C(s32 arg0){
func_802FDD20();
D_803815D0 = 1.0f;
return &D_803815F0;
}
f32 func_802FDE60(f32 arg0) {
f32 temp_f2;
f32 phi_f0;
temp_f2 = (f32) ((f64) (D_803815D4 - 1.0f) * 60.0);
if (arg0 <= temp_f2) {
phi_f0 = temp_f2 - arg0;
} else {
phi_f0 = -(temp_f2 - arg0);
}
if ((f64) phi_f0 < 2.0) {
return temp_f2;
}
return arg0;
}
#if 1
#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_76D90/func_802FDEE0.s")
#else
void func_802FDEE0(s32 arg0, struct8s *arg1, Gfx **arg2, Mtx **arg3, s32 *arg4){
s32 sp134;
f32 sp130;
f32 sp124;
s32 phi_a1;
s32 phi_s4;
s32 phi_v0;
s32 phi_v1;
f64 phi_f24;
f32 temp_f30;
s32 i;
if(!D_8036A010)
return;
phi_a1 = (D_803815C0 == 2) ? ((D_8036A014) ? D_8036A014: D_8036A010) : D_8036A010;
//func_80347FC0(arg2, phi_a1, 0, 0, 0, 0, 0, 2, 2, &sp13C, &sp138);
func_8024C7B8(arg2, arg3);
gSPDisplayList((*arg2)++, D_8036A030);
phi_s4 = 2;
for(sp134 = 0; sp134 < phi_a1; sp134++){
gDPPipeSync((*arg2)++);
if(D_803815C0 == 2){
if(sp134 != 0){
//func_80347FC0(arg2, D_8036A010, 0, 0, 0, 0, 0, phi_s4, phi_s4, &sp13C, &sp138);
gDPSetPrimColor((*arg2)++, 0, 0, 0x00, 0x00, 0x00, (0xFF - D_803815E4)& 0xFF);
}
else{
gDPSetPrimColor((*arg2)++, 0, 0, 0x00, 0x00, 0x00, D_803815E4 & 0xFF);
}
}
else{
if(D_803815D4 < D_8036A018[sp134]){
gDPSetPrimColor((*arg2)++, 0, 0, 0x00, 0x00, 0x00, 0x50);
}else if(D_803815EC && (D_803815D4 - 1.0f) == D_8036A018[sp134]){
gDPSetPrimColor((*arg2)++, 0, 0, 0x00, 0x00, 0x00, D_803815E8 & 0xFF);
}else{
gDPSetPrimColor((*arg2)++, 0, 0, 0x00, 0x00, 0x00, 0xFF);
}
}
//if statements here
temp_f30 = 244.0f - ((f32) D_80276588 / 2.0f);
sp124 = (func_802FB0E4(arg1) + ((f32) D_8027658C / 2.0f)) - 246.0f;
guTranslate(*arg3, temp_f30 * 4.0f, sp124, 0);
gSPMatrix((*arg2)++, 0x80000000 + (*arg3)++, G_MTX_NOPUSH | G_MTX_MUL | G_MTX_MODELVIEW);
guRotate(*arg3, func_802FDE60(D_803815D8 + D_803815DC), 0, 0, 1.0f);
gSPMatrix((*arg2)++, 0x80000000 + (*arg3)++, G_MTX_NOPUSH | G_MTX_MUL | G_MTX_MODELVIEW);
guScale(*arg3, D_803815E0, D_803815E0, D_803815E0);
gSPMatrix((*arg2)++, 0x80000000 + (*arg3)++, G_MTX_NOPUSH | G_MTX_MUL | G_MTX_MODELVIEW);
guTranslate(*arg3, -temp_f30 * 4.0f, -sp124 * 4.0f, 0);
gSPMatrix((*arg2)++, 0x80000000 + (*arg3)++, G_MTX_NOPUSH | G_MTX_MUL | G_MTX_MODELVIEW);
phi_f24 = _76D90_MIN(_76D90_MAX(D_803815C8, 0.0),1.0);
sp134 = temp_f18 = ((f64) cosf((f32) ((f64) (*(void *)0x803815CC + sp110) * D_803773B0)) * (phi_f24 * D_803773B8) * D_803815D0);
gSPVertex((*arg2)++, *arg4, 4, 0);
do{
for(phi_v0 = 0; phi_v0 < phi_s4; phi_v0++){
// temp_f24 = (f32) sp13C * D_803815D0;
//(*arg4)->v.ob[0] = ((((temp_f24 * (f32) phi_v0) - (temp_f24 / 2.0f)) + temp_f14) * 4.0f);
// temp_f30_2 = (f32) sp138 * D_803815D0;
//(*arg4)->v.ob[1] = ((((temp_f30_2 * (f32) phi_v0) - (temp_f30_2 / 2.0f)) + temp_f14) * 4.0f);
// (*arg4)->unk4 = (u16)-0x14;
// (*arg4)->unk8 = (s16) (((sp13C - 1) * phi_v0) << 9);
// (*arg4)->unkA = (s16) (((sp138 - 1) * phi_v1) << 9);
// *arg4 = (void *) (*arg4 + 0x10);
//(*arg4)++
}// loop43
phi_v1++;
}while(phi_v1 != phi_s4); // loop42
phi_a1 = (D_803815C0 == 2) ? ((D_8036A014) ? ++phi_s4: 1) : 6;
}
//L802FE7A0
//gSP1Quadrangle((*arg2)++, 0, 1, 3, 2, 0);
gDPPipeSync((*arg2)++);
gDPSetTextureLUT((*arg2)++, G_TT_NONE);
gDPPipelineMode((*arg2)++, G_PM_NPRIMITIVE);
func_8024C904(arg2, arg3, arg4);
//L802FE7FC
}
#endif
extern f64 D_803773E0;
void func_802FE844(s32 arg0, struct8s *arg1){
f32 sp24;
s32 sp20;
s32 tmp;
sp24 = time_getDelta();
sp20 = func_802FB0D4(arg1);
if(sp20){
D_803815D4 = itemPrint_getValue(arg0);
tmp = ((D_803815D4 - 1.0f) * 60.00000000 == func_802FDE60(D_803815D8));
if(!D_80381610 && tmp && (D_803815D4 != 1.0f))
func_8030E760(SFX_90_SWITCH_PRESS, 1.3f, 0x7FF8);
D_803815EC = (D_803815D4 == item_getCount(arg0));
D_80381610 = tmp;
if(D_803815EC && D_80381610){
D_803815E8 = _76D90_MIN(D_803815E8 + 0x10, 0xFF);
}
}//L802FE9A0
//sp24 = time_getDelta();
switch(sp20){
case 1:
if(D_8036A010 == NULL)
D_8036A010 = assetcache_get(0x7DC);
break;
case 0:
func_802FDDC4(arg0, arg1);
break;
case 2:
switch(D_803815C0){
case 0://L802FEA40
if(D_803815EC){
if(6.0f <= D_803815D4 && D_80381610 && D_803815E8 == 0xFF){
D_803815C0 = 1;
D_803815DC = 20.0f;
func_8025A6EC(COMUSIC_18_HEALTH_UPGRADE, 28000);
}else{
if(1.0f < D_803815D4 && !D_80381610){
D_803815D8 += _76D90_MAX((((D_803815D4 - 1.0f) * 60.0 - D_803815D8) * sp24 * 3.0), 2.0);
}
}
}
break;
case 1://L802FEB70
D_803815CC += 240.0f*sp24;
D_803815C8 -= sp24*0.4;
if(D_803815C8 < 0.0f){
D_803815C0 = 2;
if(D_8036A014 == NULL){
D_8036A014 = assetcache_get(0x7DD);
}
D_803815C4 = func_8023DB5C();
D_803815E4 = 0;
D_803815E0 = 0.9999f;
func_803463D4(ITEM_13_EMPTY_HONEYCOMB, -6);
timedFunc_set_2(0.25f, (TFQM2)func_8025A6EC, COMUSIC_2B_DING_B, 28000);
func_803463D4(ITEM_14_HEALTH, 0);
timedFunc_set_1(1.25f, (TFQM1)item_inc, ITEM_15_HEALTH_TOTAL);
timedFunc_set_1(1.25f, (TFQM1)func_8030E484, SFX_3EA_UNKNOWN);
timedFunc_set_2(1.25f, (TFQM2)item_set, ITEM_14_HEALTH, item_getCount(ITEM_15_HEALTH_TOTAL)+1);
timedFunc_set_1(1.5f, (TFQM1)func_80314AC8, 1);
}
break;
case 2://L802FECD4
D_803815E0 *= gu_sqrtf(D_803815E0);
D_803815DC *= 1.1;
D_803815E4 = _76D90_MIN((D_803815E4 + (400.0*sp24)), 255.0);
if(D_803815E0 < 0.1){
func_802FDD20();
func_802FDDC4(arg0, arg1);
}
break;
}
if(D_803815C0 == 1)
func_803463D4(ITEM_13_EMPTY_HONEYCOMB, 0);
break;
}
}