diff --git a/src/main/java/soot/BooleanType.java b/src/main/java/soot/BooleanType.java index e46d7b38568..ce72c7d82f3 100644 --- a/src/main/java/soot/BooleanType.java +++ b/src/main/java/soot/BooleanType.java @@ -30,6 +30,8 @@ @SuppressWarnings("serial") public class BooleanType extends PrimType implements IntegerType { + public static final int HASHCODE = 0x1C4585DA; + public BooleanType(Singletons.Global g) { } @@ -44,7 +46,7 @@ public boolean equals(Object t) { @Override public int hashCode() { - return 0x1C4585DA; + return HASHCODE; } @Override @@ -61,4 +63,14 @@ public void apply(Switch sw) { public RefType boxedType() { return RefType.v("java.lang.Boolean"); } + + @Override + public Class getJavaBoxedType() { + return Boolean.class; + } + + @Override + public Class getJavaPrimitiveType() { + return boolean.class; + } } diff --git a/src/main/java/soot/ByteType.java b/src/main/java/soot/ByteType.java index faafb721f03..99057e037d8 100644 --- a/src/main/java/soot/ByteType.java +++ b/src/main/java/soot/ByteType.java @@ -30,6 +30,8 @@ @SuppressWarnings("serial") public class ByteType extends PrimType implements IntegerType { + public static final int HASHCODE = 0x813D1329; + public ByteType(Singletons.Global g) { } @@ -39,7 +41,7 @@ public static ByteType v() { @Override public int hashCode() { - return 0x813D1329; + return HASHCODE; } @Override @@ -61,4 +63,14 @@ public void apply(Switch sw) { public RefType boxedType() { return RefType.v("java.lang.Byte"); } + + @Override + public Class getJavaBoxedType() { + return Byte.class; + } + + @Override + public Class getJavaPrimitiveType() { + return byte.class; + } } diff --git a/src/main/java/soot/CharType.java b/src/main/java/soot/CharType.java index 9d8ae1d0b68..246cab4b85a 100644 --- a/src/main/java/soot/CharType.java +++ b/src/main/java/soot/CharType.java @@ -30,6 +30,8 @@ @SuppressWarnings("serial") public class CharType extends PrimType implements IntegerType { + public static final int HASHCODE = 0x739EA474; + public CharType(Singletons.Global g) { } @@ -49,7 +51,7 @@ public String toString() { @Override public int hashCode() { - return 0x739EA474; + return HASHCODE; } @Override @@ -61,4 +63,14 @@ public void apply(Switch sw) { public RefType boxedType() { return RefType.v("java.lang.Character"); } + + @Override + public Class getJavaBoxedType() { + return Character.class; + } + + @Override + public Class getJavaPrimitiveType() { + return char.class; + } } diff --git a/src/main/java/soot/DoubleType.java b/src/main/java/soot/DoubleType.java index 80b8144cdc3..02a0e82a633 100644 --- a/src/main/java/soot/DoubleType.java +++ b/src/main/java/soot/DoubleType.java @@ -30,6 +30,8 @@ @SuppressWarnings("serial") public class DoubleType extends PrimType { + public static final int HASHCODE = 0x4B9D7242; + public DoubleType(Singletons.Global g) { } @@ -44,7 +46,7 @@ public boolean equals(Object t) { @Override public int hashCode() { - return 0x4B9D7242; + return HASHCODE; } @Override @@ -61,4 +63,14 @@ public void apply(Switch sw) { public RefType boxedType() { return RefType.v("java.lang.Double"); } + + @Override + public Class getJavaBoxedType() { + return Double.class; + } + + @Override + public Class getJavaPrimitiveType() { + return double.class; + } } diff --git a/src/main/java/soot/FloatType.java b/src/main/java/soot/FloatType.java index 14a859b6095..5e145660376 100644 --- a/src/main/java/soot/FloatType.java +++ b/src/main/java/soot/FloatType.java @@ -30,6 +30,8 @@ @SuppressWarnings("serial") public class FloatType extends PrimType { + public static final int HASHCODE = 0xA84373FA; + public FloatType(Singletons.Global g) { } @@ -44,7 +46,7 @@ public boolean equals(Object t) { @Override public int hashCode() { - return 0xA84373FA; + return HASHCODE; } @Override @@ -61,4 +63,14 @@ public void apply(Switch sw) { public RefType boxedType() { return RefType.v("java.lang.Float"); } + + @Override + public Class getJavaBoxedType() { + return Float.class; + } + + @Override + public Class getJavaPrimitiveType() { + return float.class; + } } diff --git a/src/main/java/soot/IntType.java b/src/main/java/soot/IntType.java index 7f90bcf3bdc..8c389a1b170 100644 --- a/src/main/java/soot/IntType.java +++ b/src/main/java/soot/IntType.java @@ -30,6 +30,8 @@ @SuppressWarnings("serial") public class IntType extends PrimType implements IntegerType { + public static final int HASHCODE = 0xB747239F; + public IntType(Singletons.Global g) { } @@ -44,7 +46,7 @@ public boolean equals(Object t) { @Override public int hashCode() { - return 0xB747239F; + return HASHCODE; } @Override @@ -61,4 +63,15 @@ public void apply(Switch sw) { public RefType boxedType() { return RefType.v("java.lang.Integer"); } + + @Override + public Class getJavaBoxedType() { + return Integer.class; + } + + @Override + public Class getJavaPrimitiveType() { + return int.class; + } + } diff --git a/src/main/java/soot/LongType.java b/src/main/java/soot/LongType.java index c5d0d106feb..488ac049199 100644 --- a/src/main/java/soot/LongType.java +++ b/src/main/java/soot/LongType.java @@ -30,6 +30,8 @@ @SuppressWarnings("serial") public class LongType extends PrimType { + public static final int HASHCODE = 0x023DA077; + public LongType(Singletons.Global g) { } @@ -44,7 +46,7 @@ public boolean equals(Object t) { @Override public int hashCode() { - return 0x023DA077; + return HASHCODE; } @Override @@ -61,4 +63,15 @@ public void apply(Switch sw) { public RefType boxedType() { return RefType.v("java.lang.Long"); } + + @Override + public Class getJavaBoxedType() { + return Long.class; + } + + @Override + public Class getJavaPrimitiveType() { + return long.class; + } + } diff --git a/src/main/java/soot/PrimType.java b/src/main/java/soot/PrimType.java index 16ef949e97d..75fa8f9129f 100644 --- a/src/main/java/soot/PrimType.java +++ b/src/main/java/soot/PrimType.java @@ -33,6 +33,10 @@ public abstract class PrimType extends Type { public abstract RefType boxedType(); + public abstract Class getJavaBoxedType(); + + public abstract Class getJavaPrimitiveType(); + @Override public boolean isAllowedInFinalCode() { return true; diff --git a/src/main/java/soot/ShortType.java b/src/main/java/soot/ShortType.java index fd1b8d1f33a..159e94143ef 100644 --- a/src/main/java/soot/ShortType.java +++ b/src/main/java/soot/ShortType.java @@ -30,6 +30,8 @@ @SuppressWarnings("serial") public class ShortType extends PrimType implements IntegerType { + public static final int HASHCODE = 0x8B817DD3; + public ShortType(Singletons.Global g) { } @@ -39,7 +41,7 @@ public static ShortType v() { @Override public int hashCode() { - return 0x8B817DD3; + return HASHCODE; } @Override @@ -61,4 +63,15 @@ public void apply(Switch sw) { public RefType boxedType() { return RefType.v("java.lang.Short"); } + + @Override + public Class getJavaBoxedType() { + return Short.class; + } + + @Override + public Class getJavaPrimitiveType() { + return short.class; + } + } diff --git a/src/main/java/soot/SootMethodRefImpl.java b/src/main/java/soot/SootMethodRefImpl.java index debca777213..0468f1e8671 100644 --- a/src/main/java/soot/SootMethodRefImpl.java +++ b/src/main/java/soot/SootMethodRefImpl.java @@ -29,7 +29,6 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import soot.javaToJimple.DefaultLocalGenerator; import soot.jimple.AssignStmt; import soot.jimple.InvokeStmt; import soot.jimple.Jimple; diff --git a/src/main/java/soot/jimple/toolkits/typing/fast/Integer127Type.java b/src/main/java/soot/jimple/toolkits/typing/fast/Integer127Type.java index 9337bdaebbc..cbde418c8d4 100644 --- a/src/main/java/soot/jimple/toolkits/typing/fast/Integer127Type.java +++ b/src/main/java/soot/jimple/toolkits/typing/fast/Integer127Type.java @@ -70,4 +70,14 @@ public Type getDefaultFinalType() { return ByteType.v(); } + @Override + public Class getJavaBoxedType() { + return Integer.class; + } + + @Override + public Class getJavaPrimitiveType() { + return int.class; + } + } diff --git a/src/main/java/soot/jimple/toolkits/typing/fast/Integer1Type.java b/src/main/java/soot/jimple/toolkits/typing/fast/Integer1Type.java index f88cb3a3ef1..22acccff998 100644 --- a/src/main/java/soot/jimple/toolkits/typing/fast/Integer1Type.java +++ b/src/main/java/soot/jimple/toolkits/typing/fast/Integer1Type.java @@ -70,4 +70,14 @@ public Type getDefaultFinalType() { return BooleanType.v(); } + @Override + public Class getJavaBoxedType() { + return Integer.class; + } + + @Override + public Class getJavaPrimitiveType() { + return int.class; + } + } diff --git a/src/main/java/soot/jimple/toolkits/typing/fast/Integer32767Type.java b/src/main/java/soot/jimple/toolkits/typing/fast/Integer32767Type.java index a311e15b378..a3e541ae1b2 100644 --- a/src/main/java/soot/jimple/toolkits/typing/fast/Integer32767Type.java +++ b/src/main/java/soot/jimple/toolkits/typing/fast/Integer32767Type.java @@ -69,4 +69,14 @@ public Type getDefaultFinalType() { return ShortType.v(); } + @Override + public Class getJavaBoxedType() { + return Integer.class; + } + + @Override + public Class getJavaPrimitiveType() { + return int.class; + } + } diff --git a/src/main/java/soot/jimple/toolkits/typing/fast/UseChecker.java b/src/main/java/soot/jimple/toolkits/typing/fast/UseChecker.java index c5a25aec3ea..f960c9ab38e 100644 --- a/src/main/java/soot/jimple/toolkits/typing/fast/UseChecker.java +++ b/src/main/java/soot/jimple/toolkits/typing/fast/UseChecker.java @@ -27,8 +27,10 @@ import heros.solver.Pair; import java.util.ArrayDeque; +import java.util.HashSet; import java.util.Iterator; import java.util.List; +import java.util.Set; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -294,9 +296,14 @@ public void caseAssignStmt(AssignStmt stmt) { // First, we check the definitions. If we can see the definitions and know the array type // that way, we are safe. ArrayDeque> worklist = new ArrayDeque>(); + Set> seen = new HashSet<>(); worklist.add(new Pair<>(stmt, (Local) ((ArrayRef) rhs).getBase())); while (!worklist.isEmpty()) { Pair r = worklist.removeFirst(); + if (!seen.add(r)) { + // Make sure we only process each entry once + continue; + } List d = defs.getDefsOfAt(r.getO2(), r.getO1()); if (d.isEmpty()) {