mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-09 16:34:10 -08:00
First correct local variable mapping
This commit is contained in:
parent
36d76885a7
commit
8d0432dd5e
|
@ -65,4 +65,17 @@ public class Variable implements VariableReader {
|
||||||
public void setDebugName(String debugName) {
|
public void setDebugName(String debugName) {
|
||||||
this.debugName = debugName;
|
this.debugName = debugName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void mergeDebugName(String otherDebugName) {
|
||||||
|
if (otherDebugName == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String[] parts = debugName != null ? debugName.split("\\|") : new String[0];
|
||||||
|
for (String part : parts) {
|
||||||
|
if (otherDebugName.equals(part)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
debugName = debugName != null ? debugName + "|" + otherDebugName : otherDebugName;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -214,6 +214,15 @@ public class RegisterAllocator {
|
||||||
varMap[tryCatch.getExceptionVariable().getIndex()]));
|
varMap[tryCatch.getExceptionVariable().getIndex()]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
String[] originalNames = new String[program.variableCount()];
|
||||||
|
for (int i = 0; i < program.variableCount(); ++i) {
|
||||||
|
Variable var = program.variableAt(i);
|
||||||
|
originalNames[i] = var.getDebugName();
|
||||||
|
var.setDebugName(null);
|
||||||
|
}
|
||||||
|
for (int i = 0; i < program.variableCount(); ++i) {
|
||||||
|
program.variableAt(varMap[i]).mergeDebugName(originalNames[i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void renameInterferenceGraph(List<MutableGraphNode> graph, DisjointSet classes, final int[] varMap) {
|
private void renameInterferenceGraph(List<MutableGraphNode> graph, DisjointSet classes, final int[] varMap) {
|
||||||
|
|
|
@ -112,6 +112,9 @@ public class GlobalValueNumbering implements MethodOptimization {
|
||||||
|
|
||||||
for (int i = 0; i < map.length; ++i) {
|
for (int i = 0; i < map.length; ++i) {
|
||||||
if (map[i] != i) {
|
if (map[i] != i) {
|
||||||
|
Variable var = program.variableAt(i);
|
||||||
|
Variable mapVar = program.variableAt(map[i]);
|
||||||
|
mapVar.mergeDebugName(var.getDebugName());
|
||||||
program.deleteVariable(i);
|
program.deleteVariable(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -175,12 +175,14 @@ public class SSATransformer {
|
||||||
int[] phiIndexes = phiIndexMap[successor];
|
int[] phiIndexes = phiIndexMap[successor];
|
||||||
List<Phi> phis = program.basicBlockAt(successor).getPhis();
|
List<Phi> phis = program.basicBlockAt(successor).getPhis();
|
||||||
for (int j = 0; j < phis.size(); ++j) {
|
for (int j = 0; j < phis.size(); ++j) {
|
||||||
|
Phi phi = phis.get(j);
|
||||||
Variable var = variableMap[phiIndexes[j]];
|
Variable var = variableMap[phiIndexes[j]];
|
||||||
if (var != null) {
|
if (var != null) {
|
||||||
Incoming incoming = new Incoming();
|
Incoming incoming = new Incoming();
|
||||||
incoming.setSource(currentBlock);
|
incoming.setSource(currentBlock);
|
||||||
incoming.setValue(var);
|
incoming.setValue(var);
|
||||||
phis.get(j).getIncomings().add(incoming);
|
phi.getIncomings().add(incoming);
|
||||||
|
phi.getReceiver().mergeDebugName(var.getDebugName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -391,6 +391,16 @@ function $rt_s(index) {
|
||||||
return $rt_stringPool_instance[index];
|
return $rt_stringPool_instance[index];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function $dbg_repr(obj) {
|
||||||
|
return obj.toString();
|
||||||
|
}
|
||||||
|
function $dbg_class(obj) {
|
||||||
|
if (obj instanceof Long) {
|
||||||
|
return "long";
|
||||||
|
}
|
||||||
|
return obj.constructor.$meta.name;
|
||||||
|
}
|
||||||
|
|
||||||
Long = function(lo, hi) {
|
Long = function(lo, hi) {
|
||||||
this.lo = lo | 0;
|
this.lo = lo | 0;
|
||||||
this.hi = hi | 0;
|
this.hi = hi | 0;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user