Merge pull request #1689 from GriffinRichards/task-ub
Remove UBFIX related to task destruction
This commit is contained in:
commit
c2a08cc84d
3 changed files with 12 additions and 15 deletions
|
@ -135,10 +135,12 @@ void SoundTask_PlayCryHighPitch(u8 taskId)
|
||||||
{
|
{
|
||||||
if (gBattleAnimArgs[0] == ANIM_ATTACKER)
|
if (gBattleAnimArgs[0] == ANIM_ATTACKER)
|
||||||
species = gContestResources->moveAnim->species;
|
species = gContestResources->moveAnim->species;
|
||||||
#ifndef UBFIX
|
// Destroying the task twice (here and at end of function)
|
||||||
|
// results in an incorrect value for gAnimVisualTaskCount
|
||||||
|
#ifndef BUGFIX
|
||||||
else
|
else
|
||||||
DestroyAnimVisualTask(taskId); // UB: task gets destroyed twice.
|
DestroyAnimVisualTask(taskId);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -181,10 +183,12 @@ void SoundTask_PlayDoubleCry(u8 taskId)
|
||||||
{
|
{
|
||||||
if (gBattleAnimArgs[0] == ANIM_ATTACKER)
|
if (gBattleAnimArgs[0] == ANIM_ATTACKER)
|
||||||
species = gContestResources->moveAnim->species;
|
species = gContestResources->moveAnim->species;
|
||||||
#ifndef UBFIX
|
// Destroying the task twice (here and at end of function)
|
||||||
|
// results in an incorrect value for gAnimVisualTaskCount
|
||||||
|
#ifndef BUGFIX
|
||||||
else
|
else
|
||||||
DestroyAnimVisualTask(taskId); // UB: task gets destroyed twice.
|
DestroyAnimVisualTask(taskId);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -4220,17 +4220,12 @@ static void Task_OpenMonPic(u8 taskId)
|
||||||
return;
|
return;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
#ifndef UBFIX
|
|
||||||
DestroyTask(taskId);
|
DestroyTask(taskId);
|
||||||
#endif
|
// Accessing data of destroyed task. Task data isn't reset until a new task needs that task id.
|
||||||
// UB: Should not use the task after it has been deleted.
|
|
||||||
if (gTasks[taskId].tIsSwapScreen == TRUE)
|
if (gTasks[taskId].tIsSwapScreen == TRUE)
|
||||||
Swap_CreateMonSprite();
|
Swap_CreateMonSprite();
|
||||||
else
|
else
|
||||||
Select_CreateMonSprite();
|
Select_CreateMonSprite();
|
||||||
#ifdef UBFIX
|
|
||||||
DestroyTask(taskId);
|
|
||||||
#endif
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
task->tState++;
|
task->tState++;
|
||||||
|
|
|
@ -4762,10 +4762,8 @@ static bool8 FrontierSquaresScroll_End(struct Task *task)
|
||||||
BlendPalettes(PALETTES_ALL, 16, RGB_BLACK);
|
BlendPalettes(PALETTES_ALL, 16, RGB_BLACK);
|
||||||
|
|
||||||
DestroyTask(FindTaskIdByFunc(task->func));
|
DestroyTask(FindTaskIdByFunc(task->func));
|
||||||
|
task->tState++; // Changing value of a destroyed task
|
||||||
|
|
||||||
#ifndef UBFIX
|
|
||||||
task->tState++; // UB: changing value of a destroyed task
|
|
||||||
#endif
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue