Improved logic
This commit is contained in:
parent
001acf46e2
commit
ba156ae3d2
@ -1768,13 +1768,13 @@ void clif_homunculus_updatestatus(map_session_data& sd, _sp type) {
|
|||||||
p.value = static_cast<decltype(p.value)>( std::min<decltype(sd.hd->homunculus.exp)>( sd.hd->homunculus.exp, std::numeric_limits<decltype(PACKET_ZC_PROPERTY_HOMUN::exp)>::max() ) );
|
p.value = static_cast<decltype(p.value)>( std::min<decltype(sd.hd->homunculus.exp)>( sd.hd->homunculus.exp, std::numeric_limits<decltype(PACKET_ZC_PROPERTY_HOMUN::exp)>::max() ) );
|
||||||
break;
|
break;
|
||||||
case SP_HP:
|
case SP_HP:
|
||||||
if (status->max_hp > (std::numeric_limits<decltype(PACKET_ZC_PROPERTY_HOMUN::hp)>::max() / 200))
|
if (status->max_hp > (std::numeric_limits<std::make_signed<decltype(PACKET_ZC_PROPERTY_HOMUN::hp)>::type>::max() / 100))
|
||||||
p.value = status->hp / (status->max_hp / 100);
|
p.value = status->hp / (status->max_hp / 100);
|
||||||
else
|
else
|
||||||
p.value = static_cast<decltype(p.value)>(status->hp);
|
p.value = static_cast<decltype(p.value)>(status->hp);
|
||||||
break;
|
break;
|
||||||
case SP_SP:
|
case SP_SP:
|
||||||
if (status->max_sp > (std::numeric_limits<decltype(PACKET_ZC_PROPERTY_HOMUN::sp)>::max() / 200))
|
if (status->max_sp > (std::numeric_limits<std::make_signed<decltype(PACKET_ZC_PROPERTY_HOMUN::sp)>::type>::max() / 100))
|
||||||
p.value = status->sp / (status->max_sp / 100);
|
p.value = status->sp / (status->max_sp / 100);
|
||||||
else
|
else
|
||||||
p.value = static_cast<decltype(p.value)>(status->sp);
|
p.value = static_cast<decltype(p.value)>(status->sp);
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user