Cleanup (minor optimization)
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2000-2015 JetBrains s.r.o.
|
* Copyright 2000-2016 JetBrains s.r.o.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@@ -21,6 +21,8 @@ import java.util.*;
|
|||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
|
|
||||||
public class BytecodeMappingTracer {
|
public class BytecodeMappingTracer {
|
||||||
|
public static final BytecodeMappingTracer DUMMY = new BytecodeMappingTracer();
|
||||||
|
|
||||||
private int currentSourceLine;
|
private int currentSourceLine;
|
||||||
private StructLineNumberTableAttribute lineNumberTable = null;
|
private StructLineNumberTableAttribute lineNumberTable = null;
|
||||||
private final Map<Integer, Integer> mapping = new HashMap<Integer, Integer>(); // bytecode offset, source line
|
private final Map<Integer, Integer> mapping = new HashMap<Integer, Integer>(); // bytecode offset, source line
|
||||||
@@ -116,4 +118,4 @@ public class BytecodeMappingTracer {
|
|||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -15,13 +15,6 @@
|
|||||||
*/
|
*/
|
||||||
package org.jetbrains.java.decompiler.modules.decompiler.exps;
|
package org.jetbrains.java.decompiler.modules.decompiler.exps;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map.Entry;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.jetbrains.java.decompiler.main.DecompilerContext;
|
import org.jetbrains.java.decompiler.main.DecompilerContext;
|
||||||
import org.jetbrains.java.decompiler.main.TextBuffer;
|
import org.jetbrains.java.decompiler.main.TextBuffer;
|
||||||
import org.jetbrains.java.decompiler.main.collectors.BytecodeMappingTracer;
|
import org.jetbrains.java.decompiler.main.collectors.BytecodeMappingTracer;
|
||||||
@@ -34,8 +27,10 @@ import org.jetbrains.java.decompiler.struct.match.MatchEngine;
|
|||||||
import org.jetbrains.java.decompiler.struct.match.MatchNode;
|
import org.jetbrains.java.decompiler.struct.match.MatchNode;
|
||||||
import org.jetbrains.java.decompiler.struct.match.MatchNode.RuleValue;
|
import org.jetbrains.java.decompiler.struct.match.MatchNode.RuleValue;
|
||||||
|
|
||||||
public class Exprent implements IMatchable {
|
import java.util.*;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
|
||||||
|
public class Exprent implements IMatchable {
|
||||||
public static final int MULTIPLE_USES = 1;
|
public static final int MULTIPLE_USES = 1;
|
||||||
public static final int SIDE_EFFECTS_FREE = 2;
|
public static final int SIDE_EFFECTS_FREE = 2;
|
||||||
public static final int BOTH_FLAGS = 3;
|
public static final int BOTH_FLAGS = 3;
|
||||||
@@ -144,58 +139,53 @@ public class Exprent implements IMatchable {
|
|||||||
// *****************************************************************************
|
// *****************************************************************************
|
||||||
// IMatchable implementation
|
// IMatchable implementation
|
||||||
// *****************************************************************************
|
// *****************************************************************************
|
||||||
|
|
||||||
|
@Override
|
||||||
public IMatchable findObject(MatchNode matchNode, int index) {
|
public IMatchable findObject(MatchNode matchNode, int index) {
|
||||||
|
if (matchNode.getType() != MatchNode.MATCHNODE_EXPRENT) {
|
||||||
if(matchNode.getType() != MatchNode.MATCHNODE_EXPRENT) {
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
List<Exprent> lstAllExprents = getAllExprents();
|
List<Exprent> lstAllExprents = getAllExprents();
|
||||||
|
if (lstAllExprents == null || lstAllExprents.isEmpty()) {
|
||||||
if(lstAllExprents == null || lstAllExprents.isEmpty()) {
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
String position = (String)matchNode.getRuleValue(MatchProperties.EXPRENT_POSITION);
|
String position = (String)matchNode.getRuleValue(MatchProperties.EXPRENT_POSITION);
|
||||||
if(position != null) {
|
if (position != null) {
|
||||||
if(position.matches("-?\\d+")) {
|
if (position.matches("-?\\d+")) {
|
||||||
return lstAllExprents.get((lstAllExprents.size() + Integer.parseInt(position)) % lstAllExprents.size()); // care for negative positions
|
return lstAllExprents
|
||||||
|
.get((lstAllExprents.size() + Integer.parseInt(position)) % lstAllExprents.size()); // care for negative positions
|
||||||
}
|
}
|
||||||
} else if(index < lstAllExprents.size()) { // use 'index' parameter
|
}
|
||||||
|
else if (index < lstAllExprents.size()) { // use 'index' parameter
|
||||||
return lstAllExprents.get(index);
|
return lstAllExprents.get(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public boolean match(MatchNode matchNode, MatchEngine engine) {
|
public boolean match(MatchNode matchNode, MatchEngine engine) {
|
||||||
|
if (matchNode.getType() != MatchNode.MATCHNODE_EXPRENT) {
|
||||||
if(matchNode.getType() != MatchNode.MATCHNODE_EXPRENT) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
for(Entry<MatchProperties, RuleValue> rule : matchNode.getRules().entrySet()) {
|
for (Entry<MatchProperties, RuleValue> rule : matchNode.getRules().entrySet()) {
|
||||||
switch(rule.getKey()) {
|
MatchProperties key = rule.getKey();
|
||||||
case EXPRENT_TYPE:
|
if (key == MatchProperties.EXPRENT_TYPE && this.type != ((Integer)rule.getValue().value).intValue()) {
|
||||||
if(this.type != ((Integer)rule.getValue().value).intValue()) {
|
return false;
|
||||||
return false;
|
}
|
||||||
}
|
if (key == MatchProperties.EXPRENT_RET && !engine.checkAndSetVariableValue((String)rule.getValue().value, this)) {
|
||||||
break;
|
return false;
|
||||||
case EXPRENT_RET:
|
|
||||||
if(!engine.checkAndSetVariableValue((String)rule.getValue().value, this)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return toJava(0, new BytecodeMappingTracer()).toString();
|
return toJava(0, BytecodeMappingTracer.DUMMY).toString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2000-2015 JetBrains s.r.o.
|
* Copyright 2000-2016 JetBrains s.r.o.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@@ -494,11 +494,6 @@ public class Statement implements IMatchable {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// to be overwritten
|
|
||||||
public TextBuffer toJava() {
|
|
||||||
return toJava(0, new BytecodeMappingTracer());
|
|
||||||
}
|
|
||||||
|
|
||||||
public TextBuffer toJava(int indent, BytecodeMappingTracer tracer) {
|
public TextBuffer toJava(int indent, BytecodeMappingTracer tracer) {
|
||||||
throw new RuntimeException("not implemented");
|
throw new RuntimeException("not implemented");
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user