diff options
author | Stiver <stiver.mail@gmail.com> | 2014-08-13 22:06:28 +0200 |
---|---|---|
committer | Stiver <stiver.mail@gmail.com> | 2014-08-13 22:06:28 +0200 |
commit | a2fa99e3a22f66317cfb4188f86ba5599f448891 (patch) | |
tree | cd9ed676a9b5be7268ff311958af3423d9177435 /src | |
parent | 53ad2b920ec63b1d5900357e9d4725f74031daa9 (diff) | |
download | fernflower-a2fa99e3a22f66317cfb4188f86ba5599f448891.tar fernflower-a2fa99e3a22f66317cfb4188f86ba5599f448891.tar.gz fernflower-a2fa99e3a22f66317cfb4188f86ba5599f448891.tar.lz fernflower-a2fa99e3a22f66317cfb4188f86ba5599f448891.tar.xz fernflower-a2fa99e3a22f66317cfb4188f86ba5599f448891.zip |
Fixed 'IDEA-128591: Infinite loop ignored'
Diffstat (limited to 'src')
-rw-r--r-- | src/de/fernflower/modules/decompiler/DomHelper.java | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/de/fernflower/modules/decompiler/DomHelper.java b/src/de/fernflower/modules/decompiler/DomHelper.java index 9377b30..7b3d46f 100644 --- a/src/de/fernflower/modules/decompiler/DomHelper.java +++ b/src/de/fernflower/modules/decompiler/DomHelper.java @@ -60,17 +60,17 @@ public class DomHelper { stats.addWithKey(new BasicBlockStatement(block), block.id); } + BasicBlock firstblock = graph.getFirst(); // head statement - Statement firstst = stats.getWithKey(graph.getFirst().id); + Statement firstst = stats.getWithKey(firstblock.id); // dummy exit statement Statement dummyexit = new Statement(); dummyexit.type = Statement.TYPE_DUMMYEXIT; Statement general; - if(stats.size() > 1) { + if(stats.size() > 1 || firstblock.isSuccessor(firstblock)) { // multiple basic blocks or an infinite loop of one block general = new GeneralStatement(firstst, stats, null); - } else { - // special case: one basic block + } else { // one straightforward basic block RootStatement root = new RootStatement(firstst, dummyexit); firstst.addSuccessor(new StatEdge(StatEdge.TYPE_BREAK, firstst, dummyexit, root)); |