mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-24 15:24:51 -08:00
Fix strange bug
This commit is contained in:
parent
d912ba4af3
commit
ee1b1035d2
|
@ -151,10 +151,14 @@ class LoopInversionImpl {
|
||||||
}
|
}
|
||||||
|
|
||||||
private LoopWithExits getLoopWithExits(Map<Loop, LoopWithExits> cache, Loop loop) {
|
private LoopWithExits getLoopWithExits(Map<Loop, LoopWithExits> cache, Loop loop) {
|
||||||
return cache.computeIfAbsent(loop, key ->
|
LoopWithExits result = cache.get(loop);
|
||||||
new LoopWithExits(key.getHead(), key.getParent() != null
|
if (result == null) {
|
||||||
? getLoopWithExits(cache, key.getParent())
|
result = new LoopWithExits(loop.getHead(), loop.getParent() != null
|
||||||
: null));
|
? getLoopWithExits(cache, loop.getParent())
|
||||||
|
: null);
|
||||||
|
cache.put(loop, result);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void sortLoops(LoopWithExits loop, Set<LoopWithExits> visited, List<LoopWithExits> target) {
|
private void sortLoops(LoopWithExits loop, Set<LoopWithExits> visited, List<LoopWithExits> target) {
|
||||||
|
@ -302,9 +306,7 @@ class LoopInversionImpl {
|
||||||
|
|
||||||
private IntSet nodesToCopy() {
|
private IntSet nodesToCopy() {
|
||||||
IntSet result = new IntOpenHashSet();
|
IntSet result = new IntOpenHashSet();
|
||||||
int[] nodes = this.nodes.toArray();
|
for (int node : nodes.toArray()) {
|
||||||
Arrays.sort(nodes);
|
|
||||||
for (int node : nodes) {
|
|
||||||
if (node == head || (node != bodyStart && !dom.dominates(bodyStart, node))) {
|
if (node == head || (node != bodyStart && !dom.dominates(bodyStart, node))) {
|
||||||
result.add(node);
|
result.add(node);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user