Fixed certain object desyncs

Prevented friendly lakitu and 1up spawners from desyncing the object table
Resynchronized 1up spawners
Increased max packet size to 2048
This commit is contained in:
MysterD 2022-02-15 22:04:01 -08:00
parent 265d23892b
commit 8c0e3460f6
7 changed files with 86 additions and 41 deletions

View file

@ -21,6 +21,7 @@ Contributors:
Filipianosol Filipianosol
GammaTendonNine GammaTendonNine
gunvalk gunvalk
IsaacBrumby
Llennpie Llennpie
LuigiNoodle LuigiNoodle
PeachyPeach PeachyPeach

View file

@ -32,6 +32,7 @@ void bhv_camera_lakitu_init(void) {
// Despawn unless this is the very beginning of the game // Despawn unless this is the very beginning of the game
if (gShouldNotPlayCastleMusic != TRUE) { if (gShouldNotPlayCastleMusic != TRUE) {
obj_mark_for_deletion(o); obj_mark_for_deletion(o);
return;
} }
} else { } else {
spawn_object_relative_with_scale(CLOUD_BP_LAKITU_CLOUD, 0, 0, 0, 2.0f, o, MODEL_MIST, bhvCloud); spawn_object_relative_with_scale(CLOUD_BP_LAKITU_CLOUD, 0, 0, 0, 2.0f, o, MODEL_MIST, bhvCloud);

View file

@ -1,19 +1,12 @@
// mushroom_1up.c.inc // mushroom_1up.c.inc
void bhv_1up_interact(void) { void bhv_1up_interact(void) {
if (o->activeFlags == ACTIVE_FLAG_DEACTIVATED) { return; }
UNUSED s32 sp1C;
struct MarioState* marioState = nearest_mario_state_to_object(o); struct MarioState* marioState = nearest_mario_state_to_object(o);
u8 hitLocalPlayer = (marioState->playerIndex == 0) && (obj_check_if_collided_with_object(o, marioState->marioObj) == 1); if (marioState->playerIndex == 0 && obj_check_if_collided_with_object(o, marioState->marioObj) == 1) {
if (hitLocalPlayer || (o->oInteractStatus & INT_STATUS_INTERACTED)) {
play_sound(SOUND_GENERAL_COLLECT_1UP, gDefaultSoundArgs); play_sound(SOUND_GENERAL_COLLECT_1UP, gDefaultSoundArgs);
gMarioState[0].numLives++; marioState->numLives++;
o->activeFlags = ACTIVE_FLAG_DEACTIVATED; o->activeFlags = ACTIVE_FLAG_DEACTIVATED;
if (hitLocalPlayer) { network_send_collect_item(o);
network_send_collect_item(o);
}
} }
} }
@ -220,11 +213,23 @@ void bhv_1up_jump_on_approach_loop(void) {
void bhv_1up_hidden_loop(void) { void bhv_1up_hidden_loop(void) {
if (!network_sync_object_initialized(o)) { if (!network_sync_object_initialized(o)) {
network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS); network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS);
network_init_object_field(o, &o->oPosX);
network_init_object_field(o, &o->oPosY);
network_init_object_field(o, &o->oPosZ);
network_init_object_field(o, &o->oVelX);
network_init_object_field(o, &o->oVelY); network_init_object_field(o, &o->oVelY);
network_init_object_field(o, &o->oVelZ);
network_init_object_field(o, &o->oAction); network_init_object_field(o, &o->oAction);
network_init_object_field(o, &o->oForwardVel);
network_init_object_field(o, &o->o1UpHiddenUnkF4);
network_init_object_field(o, &o->header.gfx.node.flags); network_init_object_field(o, &o->header.gfx.node.flags);
network_init_object_field(o, &o->activeFlags);
network_init_object_field(o, &o->oIntangibleTimer);
} }
s16 sp26; s16 sp26;
s32 cacheAction = o->oAction;
s32 cacheActiveFlags = o->activeFlags;
switch (o->oAction) { switch (o->oAction) {
case 0: case 0:
o->header.gfx.node.flags |= GRAPH_RENDER_INVISIBLE; o->header.gfx.node.flags |= GRAPH_RENDER_INVISIBLE;
@ -233,7 +238,6 @@ void bhv_1up_hidden_loop(void) {
o->oAction = 3; o->oAction = 3;
o->header.gfx.node.flags &= ~GRAPH_RENDER_INVISIBLE; o->header.gfx.node.flags &= ~GRAPH_RENDER_INVISIBLE;
play_sound(SOUND_GENERAL2_1UP_APPEAR, gDefaultSoundArgs); play_sound(SOUND_GENERAL2_1UP_APPEAR, gDefaultSoundArgs);
network_send_object(o);
} }
break; break;
@ -263,33 +267,47 @@ void bhv_1up_hidden_loop(void) {
} }
break; break;
} }
if (cacheAction != o->oAction || cacheActiveFlags != o->activeFlags) {
network_send_object(o);
}
} }
void bhv_1up_hidden_trigger_loop(void) { void bhv_1up_hidden_trigger_loop(void) {
if (!network_sync_object_initialized(o)) { if (!network_sync_object_initialized(o)) {
network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS); network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS);
network_init_object_field(o, &o->o1UpForceSpawn); network_init_object_field(o, &o->activeFlags);
} }
struct Object* player = nearest_player_to_object(o); struct Object* player = nearest_player_to_object(o);
struct Object *sp1C; if (player == gMarioStates[0].marioObj && obj_check_if_collided_with_object(o, player) == 1) {
if (o->o1UpForceSpawn || obj_check_if_collided_with_object(o, player) == 1) { struct Object *hiddenObj = cur_obj_nearest_object_with_behavior(bhvHidden1up);
sp1C = cur_obj_nearest_object_with_behavior(bhvHidden1up); if (hiddenObj != NULL) {
if (sp1C != NULL) hiddenObj->o1UpHiddenUnkF4++;
sp1C->o1UpHiddenUnkF4++; network_send_object(hiddenObj);
o->o1UpForceSpawn = TRUE; }
network_send_object(o);
o->activeFlags = ACTIVE_FLAG_DEACTIVATED; o->activeFlags = ACTIVE_FLAG_DEACTIVATED;
} network_send_object(o);
}
} }
void bhv_1up_hidden_in_pole_loop(void) { void bhv_1up_hidden_in_pole_loop(void) {
if (!network_sync_object_initialized(o)) { if (!network_sync_object_initialized(o)) {
network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS); network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS);
network_init_object_field(o, &o->oVelX);
network_init_object_field(o, &o->oVelY); network_init_object_field(o, &o->oVelY);
network_init_object_field(o, &o->oVelZ);
network_init_object_field(o, &o->oAction); network_init_object_field(o, &o->oAction);
network_init_object_field(o, &o->oForwardVel);
network_init_object_field(o, &o->o1UpHiddenUnkF4);
network_init_object_field(o, &o->header.gfx.node.flags); network_init_object_field(o, &o->header.gfx.node.flags);
network_init_object_field(o, &o->activeFlags);
network_init_object_field(o, &o->oIntangibleTimer);
} }
UNUSED s16 sp26; UNUSED s16 sp26;
s32 cacheAction = o->oAction;
s32 cacheActiveFlags = o->activeFlags;
switch (o->oAction) { switch (o->oAction) {
case 0: case 0:
o->header.gfx.node.flags |= GRAPH_RENDER_INVISIBLE; o->header.gfx.node.flags |= GRAPH_RENDER_INVISIBLE;
@ -298,7 +316,6 @@ void bhv_1up_hidden_in_pole_loop(void) {
o->oAction = 3; o->oAction = 3;
o->header.gfx.node.flags &= ~GRAPH_RENDER_INVISIBLE; o->header.gfx.node.flags &= ~GRAPH_RENDER_INVISIBLE;
play_sound(SOUND_GENERAL2_1UP_APPEAR, gDefaultSoundArgs); play_sound(SOUND_GENERAL2_1UP_APPEAR, gDefaultSoundArgs);
network_send_object(o);
} }
break; break;
@ -321,33 +338,62 @@ void bhv_1up_hidden_in_pole_loop(void) {
} }
break; break;
} }
if (cacheAction != o->oAction || cacheActiveFlags != o->activeFlags) {
network_send_object(o);
}
} }
void bhv_1up_hidden_in_pole_trigger_loop(void) { void bhv_1up_hidden_in_pole_trigger_loop(void) {
if (!network_sync_object_initialized(o)) { if (!network_sync_object_initialized(o)) {
network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS); network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS);
network_init_object_field(o, &o->o1UpForceSpawn); network_init_object_field(o, &o->activeFlags);
} }
struct Object *sp1C;
struct Object* player = nearest_player_to_object(o); struct Object* player = nearest_player_to_object(o);
if (o->o1UpForceSpawn || obj_check_if_collided_with_object(o, player) == 1) { if (player == gMarioStates[0].marioObj && obj_check_if_collided_with_object(o, player) == 1) {
sp1C = cur_obj_nearest_object_with_behavior(bhvHidden1upInPole); struct Object *hiddenObj = cur_obj_nearest_object_with_behavior(bhvHidden1upInPole);
if (sp1C != NULL) { if (hiddenObj != NULL) {
sp1C->o1UpHiddenUnkF4++; hiddenObj->o1UpHiddenUnkF4++;
network_send_object(hiddenObj);
} }
o->o1UpForceSpawn = TRUE;
network_send_object(o);
o->activeFlags = ACTIVE_FLAG_DEACTIVATED; o->activeFlags = ACTIVE_FLAG_DEACTIVATED;
network_send_object(o);
} }
} }
void bhv_1up_hidden_in_pole_spawner_loop(void) { void bhv_1up_hidden_in_pole_spawner_loop(void) {
// immediately break this into bhvHidden1upInPole and bhvHidden1upInPoleTrigger if (!network_sync_object_initialized(o)) {
// this makes syncing easier network_init_object(o, SYNC_DISTANCE_ONLY_EVENTS);
spawn_object_relative(2, 0, 50, 0, o, MODEL_1UP, bhvHidden1upInPole); network_init_object_field(o, &o->activeFlags);
for (s8 sp2F = 0; sp2F < 2; sp2F++) { }
spawn_object_relative(0, 0, sp2F * -200, 0, o, MODEL_NONE, bhvHidden1upInPoleTrigger);
if (gNetworkAreaSyncing || !gNetworkAreaLoaded) {
return;
}
struct Object* player = nearest_player_to_object(o);
int distanceToPlayer = dist_between_objects(o, player);
if (player == gMarioStates[0].marioObj && distanceToPlayer < 700) {
struct Object* spawn_objects[3];
u32 models[3];
spawn_objects[0] = spawn_object_relative(2, 0, 50, 0, o, MODEL_1UP, bhvHidden1upInPole);
models[0] = MODEL_1UP;
for (s8 sp2F = 0; sp2F < 2; sp2F++) {
spawn_objects[1 + sp2F] = spawn_object_relative(0, 0, sp2F * -200, 0, o, MODEL_NONE, bhvHidden1upInPoleTrigger);
models[1 + sp2F] = MODEL_NONE;
}
for (int i = 0; i < 3; i++) {
spawn_objects[i]->parentObj = spawn_objects[i];
network_set_sync_id(spawn_objects[i]);
}
o->activeFlags = ACTIVE_FLAG_DEACTIVATED;
network_send_object(o);
network_send_spawn_objects(spawn_objects, models, 3);
} }
o->activeFlags = ACTIVE_FLAG_DEACTIVATED;
} }

View file

@ -22,7 +22,7 @@ extern struct MarioState gMarioStates[];
#define SYNC_DISTANCE_INFINITE 0 #define SYNC_DISTANCE_INFINITE 0
#define MAX_SYNC_OBJECTS 256 // note: increasing this requires code to be rewritten #define MAX_SYNC_OBJECTS 256 // note: increasing this requires code to be rewritten
#define MAX_SYNC_OBJECT_FIELDS 64 #define MAX_SYNC_OBJECT_FIELDS 64
#define PACKET_LENGTH 1024 #define PACKET_LENGTH 2048
#define NETWORKTYPESTR (gNetworkType == NT_CLIENT \ #define NETWORKTYPESTR (gNetworkType == NT_CLIENT \
? "Client" \ ? "Client" \
: (gNetworkType == NT_SERVER ? "Server" : " None ")) \ : (gNetworkType == NT_SERVER ? "Server" : " None ")) \

View file

@ -7,7 +7,7 @@
#include <assert.h> #include <assert.h>
#include <stdbool.h> #include <stdbool.h>
#define PACKET_LENGTH 1024 #define PACKET_LENGTH 2048
#define PACKET_DESTINATION_BROADCAST ((u8)-1) #define PACKET_DESTINATION_BROADCAST ((u8)-1)
struct NetworkPlayer; struct NetworkPlayer;

View file

@ -56,9 +56,6 @@ void network_receive_debug_sync(struct Packet* p) {
} }
if (!hasMismatch) { return; } if (!hasMismatch) { return; }
extern s16 gCurrCourseNum;
if (gCurrCourseNum == 0) { return; }
LOG_INFO(" "); LOG_INFO(" ");
LOG_INFO("Sync Object Table Mismatch"); LOG_INFO("Sync Object Table Mismatch");
for (int i = 0; i < MAX_SYNC_OBJECTS; i++) { for (int i = 0; i < MAX_SYNC_OBJECTS; i++) {

View file

@ -158,7 +158,7 @@ void network_receive_level_macro(struct Packet* p) {
struct Object* o = get_object_matching_respawn_info(respawnInfo); struct Object* o = get_object_matching_respawn_info(respawnInfo);
if (o != NULL) { if (o != NULL) {
obj_mark_for_deletion(o); obj_mark_for_deletion(o);
LOG_INFO("rx macro deletion: object"); LOG_INFO("rx macro deletion: object, behavior: %d", get_id_from_behavior(o->behavior));
if (o->oSyncID != 0) { if (o->oSyncID != 0) {
struct SyncObject* so = &gSyncObjects[o->oSyncID]; struct SyncObject* so = &gSyncObjects[o->oSyncID];
if (so->o == o) { if (so->o == o) {