mirror of
https://github.com/xomboverlord/ldc.git
synced 2026-04-18 01:39:03 +02:00
Fix white space.
This commit is contained in:
154
dmd/optimize.c
154
dmd/optimize.c
@@ -1,6 +1,6 @@
|
||||
|
||||
// Compiler implementation of the D programming language
|
||||
// Copyright (c) 1999-2012 by Digital Mars
|
||||
// Copyright (c) 1999-2012 by Digital Mars
|
||||
// All Rights Reserved
|
||||
// written by Walter Bright
|
||||
// http://www.digitalmars.com
|
||||
@@ -40,7 +40,7 @@ static real_t zero; // work around DMC bug for now
|
||||
* return that initializer.
|
||||
*/
|
||||
|
||||
Expression *fromConstInitializer(int result, Expression *e1)
|
||||
Expression *fromConstInitializer(int result, Expression *e1)
|
||||
{
|
||||
//printf("fromConstInitializer(%s)\n", e1->toChars());
|
||||
if (e1->op == TOKvar)
|
||||
@@ -48,13 +48,13 @@ Expression *fromConstInitializer(int result, Expression *e1)
|
||||
VarDeclaration *v = ve->var->isVarDeclaration();
|
||||
if (v && !v->originalType && v->scope) // semantic() not yet run
|
||||
v->semantic (v->scope);
|
||||
if (!v || !v->type)
|
||||
return e1;
|
||||
Type * tb = v->type->toBasetype();
|
||||
if (v->isConst() && v->init
|
||||
&& (result & WANTinterpret || (tb->isscalar() ||
|
||||
((result & WANTexpand) && (tb->ty != Tsarray && tb->ty != Tstruct))))
|
||||
)
|
||||
if (!v || !v->type)
|
||||
return e1;
|
||||
Type * tb = v->type->toBasetype();
|
||||
if (v->isConst() && v->init
|
||||
&& (result & WANTinterpret || (tb->isscalar() ||
|
||||
((result & WANTexpand) && (tb->ty != Tsarray && tb->ty != Tstruct))))
|
||||
)
|
||||
{ Expression *ei = v->init->toExpression();
|
||||
if (ei && ei->type)
|
||||
e1 = ei;
|
||||
@@ -72,7 +72,7 @@ Expression *Expression::optimize(int result)
|
||||
|
||||
Expression *VarExp::optimize(int result)
|
||||
{
|
||||
return fromConstInitializer(result, this);
|
||||
return fromConstInitializer(result, this);
|
||||
return this;
|
||||
}
|
||||
|
||||
@@ -122,11 +122,11 @@ Expression *StructLiteralExp::optimize(int result)
|
||||
if (elements)
|
||||
{
|
||||
for (size_t i = 0; i < elements->dim; i++)
|
||||
{ Expression *e = (*elements)[i];
|
||||
{ Expression *e = (*elements)[i];
|
||||
if (!e)
|
||||
continue;
|
||||
e = e->optimize(WANTvalue | (result & WANTinterpret));
|
||||
(*elements)[i] = e;
|
||||
(*elements)[i] = e;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
@@ -329,20 +329,20 @@ Expression *NewExp::optimize(int result)
|
||||
if (newargs)
|
||||
{
|
||||
for (size_t i = 0; i < newargs->dim; i++)
|
||||
{ Expression *e = newargs->tdata()[i];
|
||||
{ Expression *e = newargs->tdata()[i];
|
||||
|
||||
e = e->optimize(WANTvalue);
|
||||
newargs->tdata()[i] = e;
|
||||
newargs->tdata()[i] = e;
|
||||
}
|
||||
}
|
||||
|
||||
if (arguments)
|
||||
{
|
||||
for (size_t i = 0; i < arguments->dim; i++)
|
||||
{ Expression *e = arguments->tdata()[i];
|
||||
{ Expression *e = arguments->tdata()[i];
|
||||
|
||||
e = e->optimize(WANTvalue);
|
||||
arguments->tdata()[i] = e;
|
||||
arguments->tdata()[i] = e;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
@@ -357,10 +357,10 @@ Expression *CallExp::optimize(int result)
|
||||
if (arguments)
|
||||
{
|
||||
for (size_t i = 0; i < arguments->dim; i++)
|
||||
{ Expression *e = arguments->tdata()[i];
|
||||
{ Expression *e = arguments->tdata()[i];
|
||||
|
||||
e = e->optimize(WANTvalue);
|
||||
arguments->tdata()[i] = e;
|
||||
arguments->tdata()[i] = e;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -391,7 +391,7 @@ Expression *CastExp::optimize(int result)
|
||||
|
||||
e1 = e1->optimize(result);
|
||||
if (result & WANTinterpret)
|
||||
e1 = fromConstInitializer(result, e1);
|
||||
e1 = fromConstInitializer(result, e1);
|
||||
|
||||
if ((e1->op == TOKstring || e1->op == TOKarrayliteral) &&
|
||||
(type->ty == Tpointer || type->ty == Tarray) &&
|
||||
@@ -466,8 +466,8 @@ Expression *BinExp::optimize(int result)
|
||||
{
|
||||
dinteger_t i2 = e2->toInteger();
|
||||
d_uns64 sz = e1->type->size() * 8;
|
||||
if (i2 < 0 || i2 >= sz)
|
||||
{ error("shift assign by %jd is outside the range 0..%zu", i2, sz - 1);
|
||||
if (i2 < 0 || i2 >= sz)
|
||||
{ error("shift assign by %jd is outside the range 0..%zu", i2, sz - 1);
|
||||
e2 = new IntegerExp(0);
|
||||
}
|
||||
}
|
||||
@@ -561,8 +561,8 @@ Expression *shift_optimize(int result, BinExp *e, Expression *(*shift)(Type *, E
|
||||
{
|
||||
dinteger_t i2 = e->e2->toInteger();
|
||||
d_uns64 sz = e->e1->type->size() * 8;
|
||||
if (i2 < 0 || i2 >= sz)
|
||||
{ e->error("shift by %jd is outside the range 0..%zu", i2, sz - 1);
|
||||
if (i2 < 0 || i2 >= sz)
|
||||
{ e->error("shift by %jd is outside the range 0..%zu", i2, sz - 1);
|
||||
e->e2 = new IntegerExp(0);
|
||||
}
|
||||
if (e->e1->isConst() == 1)
|
||||
@@ -644,7 +644,7 @@ Expression *CommaExp::optimize(int result)
|
||||
|
||||
e1 = e1->optimize(result & WANTinterpret);
|
||||
e2 = e2->optimize(result);
|
||||
if (!e1 || e1->op == TOKint64 || e1->op == TOKfloat64 || !e1->hasSideEffect())
|
||||
if (!e1 || e1->op == TOKint64 || e1->op == TOKfloat64 || !e1->hasSideEffect())
|
||||
{
|
||||
e = e2;
|
||||
if (e)
|
||||
@@ -660,7 +660,7 @@ Expression *ArrayLengthExp::optimize(int result)
|
||||
{ Expression *e;
|
||||
|
||||
//printf("ArrayLengthExp::optimize(result = %d) %s\n", result, toChars());
|
||||
e1 = e1->optimize(WANTvalue | WANTexpand | (result & WANTinterpret));
|
||||
e1 = e1->optimize(WANTvalue | WANTexpand | (result & WANTinterpret));
|
||||
e = this;
|
||||
if (e1->op == TOKstring || e1->op == TOKarrayliteral || e1->op == TOKassocarrayliteral)
|
||||
{
|
||||
@@ -677,8 +677,8 @@ Expression *EqualExp::optimize(int result)
|
||||
e2 = e2->optimize(WANTvalue | (result & WANTinterpret));
|
||||
e = this;
|
||||
|
||||
Expression *e1 = fromConstInitializer(result, this->e1);
|
||||
Expression *e2 = fromConstInitializer(result, this->e2);
|
||||
Expression *e1 = fromConstInitializer(result, this->e1);
|
||||
Expression *e2 = fromConstInitializer(result, this->e2);
|
||||
|
||||
e = Equal(op, type, e1, e2);
|
||||
if (e == EXP_CANT_INTERPRET)
|
||||
@@ -703,40 +703,40 @@ Expression *IdentityExp::optimize(int result)
|
||||
return e;
|
||||
}
|
||||
|
||||
|
||||
/* It is possible for constant folding to change an array expression of
|
||||
* unknown length, into one where the length is known.
|
||||
* If the expression 'arr' is a literal, set lengthVar to be its length.
|
||||
*/
|
||||
void setLengthVarIfKnown(VarDeclaration *lengthVar, Expression *arr)
|
||||
{
|
||||
if (!lengthVar)
|
||||
return;
|
||||
if (lengthVar->init && !lengthVar->init->isVoidInitializer())
|
||||
return; // we have previously calculated the length
|
||||
size_t len;
|
||||
if (arr->op == TOKstring)
|
||||
len = ((StringExp *)arr)->len;
|
||||
else if (arr->op == TOKarrayliteral)
|
||||
len = ((ArrayLiteralExp *)arr)->elements->dim;
|
||||
else
|
||||
return; // we don't know the length yet
|
||||
|
||||
Expression *dollar = new IntegerExp(0, len, Type::tsize_t);
|
||||
lengthVar->init = new ExpInitializer(0, dollar);
|
||||
lengthVar->storage_class |= STCstatic | STCconst;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* It is possible for constant folding to change an array expression of
|
||||
* unknown length, into one where the length is known.
|
||||
* If the expression 'arr' is a literal, set lengthVar to be its length.
|
||||
*/
|
||||
void setLengthVarIfKnown(VarDeclaration *lengthVar, Expression *arr)
|
||||
{
|
||||
if (!lengthVar)
|
||||
return;
|
||||
if (lengthVar->init && !lengthVar->init->isVoidInitializer())
|
||||
return; // we have previously calculated the length
|
||||
size_t len;
|
||||
if (arr->op == TOKstring)
|
||||
len = ((StringExp *)arr)->len;
|
||||
else if (arr->op == TOKarrayliteral)
|
||||
len = ((ArrayLiteralExp *)arr)->elements->dim;
|
||||
else
|
||||
return; // we don't know the length yet
|
||||
|
||||
Expression *dollar = new IntegerExp(0, len, Type::tsize_t);
|
||||
lengthVar->init = new ExpInitializer(0, dollar);
|
||||
lengthVar->storage_class |= STCstatic | STCconst;
|
||||
}
|
||||
|
||||
|
||||
Expression *IndexExp::optimize(int result)
|
||||
{ Expression *e;
|
||||
|
||||
//printf("IndexExp::optimize(result = %d) %s\n", result, toChars());
|
||||
Expression *e1 = this->e1->optimize(WANTvalue | (result & WANTinterpret));
|
||||
if (result & WANTinterpret)
|
||||
e1 = fromConstInitializer(result, e1);
|
||||
// We might know $ now
|
||||
setLengthVarIfKnown(lengthVar, e1);
|
||||
e1 = fromConstInitializer(result, e1);
|
||||
// We might know $ now
|
||||
setLengthVarIfKnown(lengthVar, e1);
|
||||
e2 = e2->optimize(WANTvalue | (result & WANTinterpret));
|
||||
e = Index(type, e1, e2);
|
||||
if (e == EXP_CANT_INTERPRET)
|
||||
@@ -744,7 +744,7 @@ Expression *IndexExp::optimize(int result)
|
||||
return e;
|
||||
}
|
||||
|
||||
|
||||
|
||||
Expression *SliceExp::optimize(int result)
|
||||
{ Expression *e;
|
||||
|
||||
@@ -761,15 +761,15 @@ Expression *SliceExp::optimize(int result)
|
||||
return e;
|
||||
}
|
||||
if (result & WANTinterpret)
|
||||
e1 = fromConstInitializer(result, e1);
|
||||
// We might know $ now
|
||||
setLengthVarIfKnown(lengthVar, e1);
|
||||
e1 = fromConstInitializer(result, e1);
|
||||
// We might know $ now
|
||||
setLengthVarIfKnown(lengthVar, e1);
|
||||
lwr = lwr->optimize(WANTvalue | (result & WANTinterpret));
|
||||
upr = upr->optimize(WANTvalue | (result & WANTinterpret));
|
||||
e = Slice(type, e1, lwr, upr);
|
||||
if (e == EXP_CANT_INTERPRET)
|
||||
e = this;
|
||||
//printf("-SliceExp::optimize() %s\n", e->toChars());
|
||||
//printf("-SliceExp::optimize() %s\n", e->toChars());
|
||||
return e;
|
||||
}
|
||||
|
||||
@@ -781,12 +781,12 @@ Expression *AndAndExp::optimize(int result)
|
||||
e = this;
|
||||
if (e1->isBool(FALSE))
|
||||
{
|
||||
if (type->toBasetype()->ty == Tvoid)
|
||||
e = e2;
|
||||
else
|
||||
{ e = new CommaExp(loc, e1, new IntegerExp(loc, 0, type));
|
||||
e->type = type;
|
||||
}
|
||||
if (type->toBasetype()->ty == Tvoid)
|
||||
e = e2;
|
||||
else
|
||||
{ e = new CommaExp(loc, e1, new IntegerExp(loc, 0, type));
|
||||
e->type = type;
|
||||
}
|
||||
e = e->optimize(result);
|
||||
}
|
||||
else
|
||||
@@ -803,11 +803,11 @@ Expression *AndAndExp::optimize(int result)
|
||||
e = new IntegerExp(loc, n1 && n2, type);
|
||||
}
|
||||
else if (e1->isBool(TRUE))
|
||||
{
|
||||
if (type->toBasetype()->ty == Tvoid)
|
||||
e = e2;
|
||||
else e = new BoolExp(loc, e2, type);
|
||||
}
|
||||
{
|
||||
if (type->toBasetype()->ty == Tvoid)
|
||||
e = e2;
|
||||
else e = new BoolExp(loc, e2, type);
|
||||
}
|
||||
}
|
||||
}
|
||||
return e;
|
||||
@@ -838,12 +838,12 @@ Expression *OrOrExp::optimize(int result)
|
||||
e = new IntegerExp(loc, n1 || n2, type);
|
||||
}
|
||||
else if (e1->isBool(FALSE))
|
||||
{
|
||||
if (type->toBasetype()->ty == Tvoid)
|
||||
e = e2;
|
||||
else
|
||||
e = new BoolExp(loc, e2, type);
|
||||
}
|
||||
{
|
||||
if (type->toBasetype()->ty == Tvoid)
|
||||
e = e2;
|
||||
else
|
||||
e = new BoolExp(loc, e2, type);
|
||||
}
|
||||
}
|
||||
}
|
||||
return e;
|
||||
|
||||
Reference in New Issue
Block a user