C backend: fix bug in type inference, fix code generation for small int and long values

This commit is contained in:
Alexey Andreev 2018-05-04 19:05:11 +03:00
parent 4530167061
commit 899725b6bd
2 changed files with 22 additions and 18 deletions

View File

@ -30,22 +30,30 @@ public final class CodeGeneratorUtil {
} else if (value instanceof Integer) { } else if (value instanceof Integer) {
int i = (Integer) value; int i = (Integer) value;
long v = i; long v = i;
if (i < 0) { if (i == Integer.MIN_VALUE) {
writer.print("-"); writer.print("(int32_t) INT32_C(0x80000000)");
v = -i; } else {
if (i < 0) {
writer.print("-");
v = -v;
}
writer.print("INT32_C(");
writeLongConstant(writer, v);
writer.print(")");
} }
writer.print("INT32_C(");
writeLongConstant(writer, v);
writer.print(")");
} else if (value instanceof Long) { } else if (value instanceof Long) {
long v = (Long) value; long v = (Long) value;
if (v < 0) { if (v == Long.MIN_VALUE) {
writer.print("-"); writer.print("(int64_t) INT64_C(0x8000000000000000)");
v = -v; } else {
if (v < 0) {
writer.print("-");
v = -v;
}
writer.print("INT64_C(");
writeLongConstant(writer, v);
writer.print(")");
} }
writer.print("INT64_C(");
writeLongConstant(writer, v);
writer.print(")");
} else if (value instanceof Float) { } else if (value instanceof Float) {
float f = (Float) value; float f = (Float) value;
if (Float.isInfinite(f)) { if (Float.isInfinite(f)) {

View File

@ -90,7 +90,8 @@ public class TypeInferer {
} }
public VariableType typeOf(int variableIndex) { public VariableType typeOf(int variableIndex) {
return types[variableIndex]; VariableType result = types[variableIndex];
return result != null ? result : VariableType.OBJECT;
} }
VariableType convert(ValueType type) { VariableType convert(ValueType type) {
@ -183,11 +184,6 @@ public class TypeInferer {
types[receiver.getIndex()] = VariableType.OBJECT; types[receiver.getIndex()] = VariableType.OBJECT;
} }
@Override
public void nullConstant(VariableReader receiver) {
types[receiver.getIndex()] = VariableType.OBJECT;
}
@Override @Override
public void nullCheck(VariableReader receiver, VariableReader value) { public void nullCheck(VariableReader receiver, VariableReader value) {
builder.addEdge(value.getIndex(), receiver.getIndex()); builder.addEdge(value.getIndex(), receiver.getIndex());