|
19 | 19 |
|
20 | 20 | package soot.jbco.jimpleTransformations;
|
21 | 21 |
|
22 |
| -import java.util.*; |
23 |
| -import soot.*; |
| 22 | +import java.util.ArrayList; |
| 23 | +import java.util.HashMap; |
| 24 | +import java.util.Iterator; |
| 25 | +import java.util.List; |
| 26 | +import java.util.Map; |
| 27 | +import java.util.Vector; |
| 28 | +import soot.Body; |
| 29 | +import soot.FastHierarchy; |
| 30 | +import soot.G; |
| 31 | +import soot.Hierarchy; |
| 32 | +import soot.Scene; |
| 33 | +import soot.SceneTransformer; |
| 34 | +import soot.SootClass; |
| 35 | +import soot.SootField; |
| 36 | +import soot.SootMethod; |
| 37 | +import soot.SootMethodRef; |
| 38 | +import soot.Unit; |
| 39 | +import soot.Value; |
| 40 | +import soot.ValueBox; |
24 | 41 | import soot.jbco.IJbcoTransform;
|
25 |
| -import soot.jbco.util.*; |
26 |
| -import soot.jimple.*; |
| 42 | +import soot.jbco.util.BodyBuilder; |
| 43 | +import soot.jbco.util.Rand; |
| 44 | +import soot.jimple.InvokeExpr; |
27 | 45 |
|
28 | 46 | /**
|
29 | 47 | * @author Michael Batchelder
|
@@ -74,7 +92,8 @@ protected void internalTransform(String phaseName,
|
74 | 92 | fields.add(fIt.next().getName());
|
75 | 93 | }
|
76 | 94 |
|
77 |
| - for (SootMethod m : c.getMethods()) { |
| 95 | + final List<SootMethod> methods = new ArrayList<>(c.getMethods()); |
| 96 | + for (SootMethod m : methods) { |
78 | 97 | String subSig = m.getSubSignature();
|
79 | 98 |
|
80 | 99 | if (!allowsRename(c, m))
|
@@ -119,7 +138,8 @@ protected void internalTransform(String phaseName,
|
119 | 138 | }
|
120 | 139 |
|
121 | 140 | for (SootClass c : scene.getApplicationClasses()) {
|
122 |
| - for (SootMethod m : c.getMethods()) { |
| 141 | + final List<SootMethod> methods = new ArrayList<>(c.getMethods()); |
| 142 | + for (SootMethod m : methods) { |
123 | 143 | if (!m.isConcrete() || m.getDeclaringClass().isLibraryClass())
|
124 | 144 | continue;
|
125 | 145 | Body aBody = null;
|
|
0 commit comments