mirror of
https://github.com/ZDoom/qzdoom.git
synced 2025-01-18 23:21:41 +00:00
Let min/max pre-solve for 2+ constants, even if there are non-constants
This commit is contained in:
parent
1ffb7ad109
commit
1f09341d2b
1 changed files with 64 additions and 53 deletions
|
@ -2065,7 +2065,6 @@ FxMinMax::FxMinMax(TArray<FxExpression*> &expr, int type, const FScriptPosition
|
||||||
FxExpression *FxMinMax::Resolve(FCompileContext &ctx)
|
FxExpression *FxMinMax::Resolve(FCompileContext &ctx)
|
||||||
{
|
{
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
bool isconst;
|
|
||||||
int intcount, floatcount;
|
int intcount, floatcount;
|
||||||
|
|
||||||
CHECKRESOLVED();
|
CHECKRESOLVED();
|
||||||
|
@ -2113,64 +2112,76 @@ FxExpression *FxMinMax::Resolve(FCompileContext &ctx)
|
||||||
ValueType = VAL_Int;
|
ValueType = VAL_Int;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Determine if every argument is constant
|
// If at least two arguments are constants, they can be solved now.
|
||||||
isconst = true;
|
|
||||||
|
// Look for first constant
|
||||||
for (i = 0; i < choices.Size(); ++i)
|
for (i = 0; i < choices.Size(); ++i)
|
||||||
{
|
{
|
||||||
if (!choices[i]->isConstant())
|
if (choices[i]->isConstant())
|
||||||
{
|
{
|
||||||
isconst = false;
|
ExpVal best = static_cast<FxConstant *>(choices[i])->GetValue();
|
||||||
|
// Compare against remaining constants, which are removed.
|
||||||
|
// The best value gets stored in this one.
|
||||||
|
for (unsigned j = i + 1; j < choices.Size(); )
|
||||||
|
{
|
||||||
|
if (!choices[j]->isConstant())
|
||||||
|
{
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ExpVal value = static_cast<FxConstant *>(choices[j])->GetValue();
|
||||||
|
assert(value.Type == ValueType.Type);
|
||||||
|
if (Type == TK_Min)
|
||||||
|
{
|
||||||
|
if (value.Type == VAL_Float)
|
||||||
|
{
|
||||||
|
if (value.Float < best.Float)
|
||||||
|
{
|
||||||
|
best.Float = value.Float;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (value.Int < best.Int)
|
||||||
|
{
|
||||||
|
best.Int = value.Int;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (value.Type == VAL_Float)
|
||||||
|
{
|
||||||
|
if (value.Float > best.Float)
|
||||||
|
{
|
||||||
|
best.Float = value.Float;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (value.Int > best.Int)
|
||||||
|
{
|
||||||
|
best.Int = value.Int;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
delete choices[j];
|
||||||
|
choices[j] = NULL;
|
||||||
|
choices.Delete(j);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
FxExpression *x = new FxConstant(best, ScriptPosition);
|
||||||
|
if (i == 0 && choices.Size() == 1)
|
||||||
|
{ // Every choice was constant
|
||||||
|
delete this;
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
delete choices[i];
|
||||||
|
choices[i] = x;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If every argument is constant, we can decide this now.
|
|
||||||
if (isconst)
|
|
||||||
{
|
|
||||||
ExpVal best = static_cast<FxConstant *>(choices[0])->GetValue();
|
|
||||||
for (i = 1; i < choices.Size(); ++i)
|
|
||||||
{
|
|
||||||
ExpVal value = static_cast<FxConstant *>(choices[i])->GetValue();
|
|
||||||
assert(value.Type == ValueType.Type);
|
|
||||||
if (Type == TK_Min)
|
|
||||||
{
|
|
||||||
if (value.Type == VAL_Float)
|
|
||||||
{
|
|
||||||
if (value.Float < best.Float)
|
|
||||||
{
|
|
||||||
best.Float = value.Float;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (value.Int < best.Int)
|
|
||||||
{
|
|
||||||
best.Int = value.Int;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (value.Type == VAL_Float)
|
|
||||||
{
|
|
||||||
if (value.Float > best.Float)
|
|
||||||
{
|
|
||||||
best.Float = value.Float;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (value.Int > best.Int)
|
|
||||||
{
|
|
||||||
best.Int = value.Int;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
FxExpression *x = new FxConstant(best, ScriptPosition);
|
|
||||||
delete this;
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue