mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-15 22:21:26 +00:00
Merge branch 'fixedrounding-hotfix' into 'next'
FixedRounding hotfix Fix the FixedFloor, FixedTrunc, FixedCeil, and FixedRound functions. See merge request !142
This commit is contained in:
commit
6d07c6baab
1 changed files with 22 additions and 6 deletions
|
@ -283,9 +283,16 @@ FUNCMATH FUNCINLINE static ATTRINLINE fixed_t FixedFloor(fixed_t x)
|
||||||
{
|
{
|
||||||
const fixed_t a = abs(x); //absolute of x
|
const fixed_t a = abs(x); //absolute of x
|
||||||
const fixed_t i = (a>>FRACBITS)<<FRACBITS; // cut out the fractional part
|
const fixed_t i = (a>>FRACBITS)<<FRACBITS; // cut out the fractional part
|
||||||
const fixed_t f = i-a; // cut out the integral part
|
const fixed_t f = a-i; // cut out the integral part
|
||||||
|
if (f == 0)
|
||||||
|
return x;
|
||||||
if (x != INT32_MIN)
|
if (x != INT32_MIN)
|
||||||
return x-f; // return largest integral value not greater than argument
|
{ // return rounded down to nearest whole number
|
||||||
|
if (x > 0)
|
||||||
|
return x-f;
|
||||||
|
else
|
||||||
|
return x-(FRACUNIT-f);
|
||||||
|
}
|
||||||
return INT32_MIN;
|
return INT32_MIN;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -301,7 +308,7 @@ FUNCMATH FUNCINLINE static ATTRINLINE fixed_t FixedTrunc(fixed_t x)
|
||||||
{
|
{
|
||||||
const fixed_t a = abs(x); //absolute of x
|
const fixed_t a = abs(x); //absolute of x
|
||||||
const fixed_t i = (a>>FRACBITS)<<FRACBITS; // cut out the fractional part
|
const fixed_t i = (a>>FRACBITS)<<FRACBITS; // cut out the fractional part
|
||||||
const fixed_t f = i-a; // cut out the integral part
|
const fixed_t f = a-i; // cut out the integral part
|
||||||
if (x != INT32_MIN)
|
if (x != INT32_MIN)
|
||||||
{ // return rounded to nearest whole number, towards zero
|
{ // return rounded to nearest whole number, towards zero
|
||||||
if (x > 0)
|
if (x > 0)
|
||||||
|
@ -324,11 +331,18 @@ FUNCMATH FUNCINLINE static ATTRINLINE fixed_t FixedCeil(fixed_t x)
|
||||||
{
|
{
|
||||||
const fixed_t a = abs(x); //absolute of x
|
const fixed_t a = abs(x); //absolute of x
|
||||||
const fixed_t i = (a>>FRACBITS)<<FRACBITS; // cut out the fractional part
|
const fixed_t i = (a>>FRACBITS)<<FRACBITS; // cut out the fractional part
|
||||||
const fixed_t f = i-a; // cut out the integral part
|
const fixed_t f = a-i; // cut out the integral part
|
||||||
|
if (f == 0)
|
||||||
|
return x;
|
||||||
if (x == INT32_MIN)
|
if (x == INT32_MIN)
|
||||||
return INT32_MIN;
|
return INT32_MIN;
|
||||||
else if (x < FixedFloor(INT32_MAX))
|
else if (x < FixedFloor(INT32_MAX))
|
||||||
return x+(FRACUNIT-f); // return smallest integral value not less than argument
|
{ // return rounded up to nearest whole number
|
||||||
|
if (x > 0)
|
||||||
|
return x+(FRACUNIT-f);
|
||||||
|
else
|
||||||
|
return x+f;
|
||||||
|
}
|
||||||
return INT32_MAX;
|
return INT32_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -344,7 +358,9 @@ FUNCMATH FUNCINLINE static ATTRINLINE fixed_t FixedRound(fixed_t x)
|
||||||
{
|
{
|
||||||
const fixed_t a = abs(x); //absolute of x
|
const fixed_t a = abs(x); //absolute of x
|
||||||
const fixed_t i = (a>>FRACBITS)<<FRACBITS; // cut out the fractional part
|
const fixed_t i = (a>>FRACBITS)<<FRACBITS; // cut out the fractional part
|
||||||
const fixed_t f = i-a; // cut out the integral part
|
const fixed_t f = a-i; // cut out the integral part
|
||||||
|
if (f == 0)
|
||||||
|
return x;
|
||||||
if (x == INT32_MIN)
|
if (x == INT32_MIN)
|
||||||
return INT32_MIN;
|
return INT32_MIN;
|
||||||
else if (x < FixedFloor(INT32_MAX))
|
else if (x < FixedFloor(INT32_MAX))
|
||||||
|
|
Loading…
Reference in a new issue