Hard Level Caps issues (#4420)
* Fix 1 exp gain on hard level caps * Level Cap issues * fix compile * brackets
This commit is contained in:
parent
6ad443c9a8
commit
48d71b0de1
3 changed files with 20 additions and 2 deletions
|
@ -4416,6 +4416,14 @@ static void Cmd_getexp(void)
|
||||||
gBattleMoveDamage += GetSoftLevelCapExpValue(gPlayerParty[*expMonId].level, gBattleStruct->expShareExpValue);;
|
gBattleMoveDamage += GetSoftLevelCapExpValue(gPlayerParty[*expMonId].level, gBattleStruct->expShareExpValue);;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (EXP_CAP_HARD && gBattleMoveDamage != 0)
|
||||||
|
{
|
||||||
|
u32 growthRate = gSpeciesInfo[GetMonData(&gPlayerParty[*expMonId], MON_DATA_SPECIES)].growthRate;
|
||||||
|
if (gExperienceTables[growthRate][GetCurrentLevelCap()] < gExperienceTables[growthRate][GetMonData(&gPlayerParty[*expMonId], MON_DATA_LEVEL)] + gBattleMoveDamage)
|
||||||
|
gBattleMoveDamage = gExperienceTables[growthRate][GetCurrentLevelCap()];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EXP_CAP_HARD || gBattleMoveDamage != 0) // Edge case for hard level caps. Prevents mons from getting 1 exp
|
||||||
ApplyExperienceMultipliers(&gBattleMoveDamage, *expMonId, gBattlerFainted);
|
ApplyExperienceMultipliers(&gBattleMoveDamage, *expMonId, gBattlerFainted);
|
||||||
|
|
||||||
if (IsTradedMon(&gPlayerParty[*expMonId]))
|
if (IsTradedMon(&gPlayerParty[*expMonId]))
|
||||||
|
@ -15987,6 +15995,7 @@ void ApplyExperienceMultipliers(s32 *expAmount, u8 expGetterMonId, u8 faintedBat
|
||||||
|
|
||||||
value *= sExperienceScalingFactors[(faintedLevel * 2) + 10];
|
value *= sExperienceScalingFactors[(faintedLevel * 2) + 10];
|
||||||
value /= sExperienceScalingFactors[faintedLevel + expGetterLevel + 10];
|
value /= sExperienceScalingFactors[faintedLevel + expGetterLevel + 10];
|
||||||
|
|
||||||
*expAmount = value + 1;
|
*expAmount = value + 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3530,9 +3530,18 @@ bool8 PokemonUseItemEffects(struct Pokemon *mon, u16 item, u8 partyIndex, u8 mov
|
||||||
{
|
{
|
||||||
u16 species = GetMonData(mon, MON_DATA_SPECIES, NULL);
|
u16 species = GetMonData(mon, MON_DATA_SPECIES, NULL);
|
||||||
dataUnsigned = sExpCandyExperienceTable[param - 1] + GetMonData(mon, MON_DATA_EXP, NULL);
|
dataUnsigned = sExpCandyExperienceTable[param - 1] + GetMonData(mon, MON_DATA_EXP, NULL);
|
||||||
if (dataUnsigned > gExperienceTables[gSpeciesInfo[species].growthRate][MAX_LEVEL])
|
|
||||||
|
if (B_RARE_CANDY_CAP && EXP_CAP_HARD)
|
||||||
|
{
|
||||||
|
u32 currentLevelCap = GetCurrentLevelCap();
|
||||||
|
if (dataUnsigned > gExperienceTables[gSpeciesInfo[species].growthRate][currentLevelCap])
|
||||||
|
dataUnsigned = gExperienceTables[gSpeciesInfo[species].growthRate][currentLevelCap];
|
||||||
|
}
|
||||||
|
else if (dataUnsigned > gExperienceTables[gSpeciesInfo[species].growthRate][MAX_LEVEL])
|
||||||
|
{
|
||||||
dataUnsigned = gExperienceTables[gSpeciesInfo[species].growthRate][MAX_LEVEL];
|
dataUnsigned = gExperienceTables[gSpeciesInfo[species].growthRate][MAX_LEVEL];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (dataUnsigned != 0) // Failsafe
|
if (dataUnsigned != 0) // Failsafe
|
||||||
{
|
{
|
||||||
|
|
BIN
tools/trainerproc/trainerproc
Executable file
BIN
tools/trainerproc/trainerproc
Executable file
Binary file not shown.
Loading…
Reference in a new issue