mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-18 04:14:50 -08:00
C backend: fix bug in type inference, fix code generation for small int and long values
This commit is contained in:
parent
4530167061
commit
899725b6bd
|
@ -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)) {
|
||||||
|
|
|
@ -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());
|
||||||
|
|
Loading…
Reference in New Issue
Block a user