# HG changeset patch # User Roland Schatz # Date 1424257804 -3600 # Node ID d216de21bfe80702d77369fdad088563a41781e5 # Parent eb2e1729433e081b23ee3ba810648b96665a252c Fix unchecked warnings in NodeClass. diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.compiler.common/src/com/oracle/graal/compiler/common/FieldIntrospection.java --- a/graal/com.oracle.graal.compiler.common/src/com/oracle/graal/compiler/common/FieldIntrospection.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.compiler.common/src/com/oracle/graal/compiler/common/FieldIntrospection.java Wed Feb 18 12:10:04 2015 +0100 @@ -24,22 +24,22 @@ import java.util.concurrent.*; -public abstract class FieldIntrospection extends UnsafeAccess { +public abstract class FieldIntrospection extends UnsafeAccess { - protected static final ConcurrentHashMap, FieldIntrospection> allClasses = new ConcurrentHashMap<>(); + protected static final ConcurrentHashMap, FieldIntrospection> allClasses = new ConcurrentHashMap<>(); - private final Class clazz; + private final Class clazz; /** * The set of fields in {@link #clazz} that do long belong to a more specific category. */ protected Fields data; - public FieldIntrospection(Class clazz) { + public FieldIntrospection(Class clazz) { this.clazz = clazz; } - public Class getClazz() { + public Class getClazz() { return clazz; } diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.graph/src/com/oracle/graal/graph/NodeClass.java --- a/graal/com.oracle.graal.graph/src/com/oracle/graal/graph/NodeClass.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.graph/src/com/oracle/graal/graph/NodeClass.java Wed Feb 18 12:10:04 2015 +0100 @@ -51,7 +51,7 @@ *
  • The identifier for an {@link IterableNodeType} class.
  • * */ -public final class NodeClass extends FieldIntrospection { +public final class NodeClass extends FieldIntrospection { // Timers for creation of a NodeClass instance private static final DebugTimer Init_FieldScanning = Debug.timer("NodeClass.Init.FieldScanning"); @@ -71,23 +71,22 @@ /** * Gets the {@link NodeClass} associated with a given {@link Class}. */ - @SuppressWarnings({"unchecked", "rawtypes"}) public static NodeClass get(Class c) { assert getNodeClassViaReflection(c) == null; - Class superclass = c.getSuperclass(); - NodeClass nodeSuperclass = null; + Class superclass = c.getSuperclass(); + NodeClass nodeSuperclass = null; if (superclass != NODE_CLASS) { nodeSuperclass = getNodeClassViaReflection(superclass); } - return new NodeClass(c, nodeSuperclass); + return new NodeClass<>(c, nodeSuperclass); } - @SuppressWarnings("rawtypes") - public static NodeClass getNodeClassViaReflection(Class superclass) { + @SuppressWarnings("unchecked") + public static NodeClass getNodeClassViaReflection(Class superclass) { try { Field field = superclass.getDeclaredField("TYPE"); field.setAccessible(true); - return (NodeClass) field.get(null); + return (NodeClass) field.get(null); } catch (IllegalArgumentException | IllegalAccessException | NoSuchFieldException | SecurityException e) { throw new RuntimeException(e); } @@ -101,7 +100,7 @@ private final InputEdges inputs; private final SuccessorEdges successors; - private final NodeClass superNodeClass; + private final NodeClass superNodeClass; private final boolean canGVN; private final int startGVNNumber; @@ -124,11 +123,11 @@ private final boolean isSimplifiable; private final boolean isLeafNode; - public NodeClass(Class clazz, NodeClass superNodeClass) { + public NodeClass(Class clazz, NodeClass superNodeClass) { this(clazz, superNodeClass, new FieldsScanner.DefaultCalcOffset(), null, 0); } - public NodeClass(Class clazz, NodeClass superNodeClass, FieldsScanner.CalcOffset calcOffset, int[] presetIterableIds, int presetIterableId) { + public NodeClass(Class clazz, NodeClass superNodeClass, FieldsScanner.CalcOffset calcOffset, int[] presetIterableIds, int presetIterableId) { super(clazz); this.superNodeClass = superNodeClass; assert NODE_CLASS.isAssignableFrom(clazz); @@ -638,7 +637,7 @@ } } - public Class getJavaClass() { + public Class getJavaClass() { return getClazz(); } diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/replacements/CompositeValueClassSubstitutions.java --- a/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/replacements/CompositeValueClassSubstitutions.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/replacements/CompositeValueClassSubstitutions.java Wed Feb 18 12:10:04 2015 +0100 @@ -65,5 +65,5 @@ } @MacroSubstitution(isStatic = true, forced = true, macro = CompositeValueClassGetNode.class) - private static native CompositeValueClass get(Class c); + private static native CompositeValueClass get(Class c); } diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.lir/src/com/oracle/graal/lir/CompositeValue.java --- a/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/CompositeValue.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/CompositeValue.java Wed Feb 18 12:10:04 2015 +0100 @@ -44,7 +44,7 @@ OperandFlag[] value() default OperandFlag.REG; } - private final CompositeValueClass valueClass; + private final CompositeValueClass valueClass; private static final DebugMetric COMPOSITE_VALUE_COUNT = Debug.metric("CompositeValues"); @@ -81,7 +81,7 @@ return false; } - CompositeValueClass getValueClass() { + CompositeValueClass getValueClass() { return valueClass; } diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.lir/src/com/oracle/graal/lir/CompositeValueClass.java --- a/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/CompositeValueClass.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/CompositeValueClass.java Wed Feb 18 12:10:04 2015 +0100 @@ -38,18 +38,19 @@ * such fields. * */ -public class CompositeValueClass extends LIRIntrospection { +public class CompositeValueClass extends LIRIntrospection { - public static final CompositeValueClass get(Class c) { - CompositeValueClass clazz = (CompositeValueClass) allClasses.get(c); + @SuppressWarnings("unchecked") + public static final CompositeValueClass get(Class c) { + CompositeValueClass clazz = (CompositeValueClass) allClasses.get(c); if (clazz != null) { return clazz; } // We can have a race of multiple threads creating the LIRInstructionClass at the same time. // However, only one will be put into the map, and this is the one returned by all threads. - clazz = new CompositeValueClass(c); - CompositeValueClass oldClazz = (CompositeValueClass) allClasses.putIfAbsent(c, clazz); + clazz = new CompositeValueClass<>(c); + CompositeValueClass oldClazz = (CompositeValueClass) allClasses.putIfAbsent(c, clazz); if (oldClazz != null) { return oldClazz; } else { @@ -57,11 +58,11 @@ } } - public CompositeValueClass(Class clazz) { + public CompositeValueClass(Class clazz) { this(clazz, new FieldsScanner.DefaultCalcOffset()); } - public CompositeValueClass(Class clazz, FieldsScanner.CalcOffset calcOffset) { + public CompositeValueClass(Class clazz, FieldsScanner.CalcOffset calcOffset) { super(clazz); CompositeValueFieldsScanner vfs = new CompositeValueFieldsScanner(calcOffset); diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstruction.java --- a/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstruction.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstruction.java Wed Feb 18 12:10:04 2015 +0100 @@ -255,5 +255,5 @@ void verify(); - LIRInstructionClass getLIRInstructionClass(); + LIRInstructionClass getLIRInstructionClass(); } diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstructionBase.java --- a/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstructionBase.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstructionBase.java Wed Feb 18 12:10:04 2015 +0100 @@ -54,7 +54,7 @@ */ protected static final EnumSet ADDRESS_FLAGS = EnumSet.of(REG, ILLEGAL); - private final LIRInstructionClass instructionClass; + private final LIRInstructionClass instructionClass; /** * Instruction id for register allocation. @@ -231,7 +231,7 @@ return instructionClass.toString(this); } - public LIRInstructionClass getLIRInstructionClass() { + public LIRInstructionClass getLIRInstructionClass() { return instructionClass; } } diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstructionClass.java --- a/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstructionClass.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRInstructionClass.java Wed Feb 18 12:10:04 2015 +0100 @@ -31,18 +31,19 @@ import com.oracle.graal.lir.LIRInstruction.OperandFlag; import com.oracle.graal.lir.LIRInstruction.OperandMode; -public class LIRInstructionClass extends LIRIntrospection { +public class LIRInstructionClass extends LIRIntrospection { - public static final LIRInstructionClass get(Class c) { - LIRInstructionClass clazz = (LIRInstructionClass) allClasses.get(c); + @SuppressWarnings("unchecked") + public static final LIRInstructionClass get(Class c) { + LIRInstructionClass clazz = (LIRInstructionClass) allClasses.get(c); if (clazz != null) { return clazz; } // We can have a race of multiple threads creating the LIRInstructionClass at the same time. // However, only one will be put into the map, and this is the one returned by all threads. - clazz = new LIRInstructionClass(c); - LIRInstructionClass oldClazz = (LIRInstructionClass) allClasses.putIfAbsent(c, clazz); + clazz = new LIRInstructionClass<>(c); + LIRInstructionClass oldClazz = (LIRInstructionClass) allClasses.putIfAbsent(c, clazz); if (oldClazz != null) { return oldClazz; } else { @@ -62,11 +63,11 @@ private String opcodeConstant; private int opcodeIndex; - private LIRInstructionClass(Class clazz) { + private LIRInstructionClass(Class clazz) { this(clazz, new FieldsScanner.DefaultCalcOffset()); } - public LIRInstructionClass(Class clazz, FieldsScanner.CalcOffset calcOffset) { + public LIRInstructionClass(Class clazz, FieldsScanner.CalcOffset calcOffset) { super(clazz); assert INSTRUCTION_CLASS.isAssignableFrom(clazz); diff -r eb2e1729433e -r d216de21bfe8 graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRIntrospection.java --- a/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRIntrospection.java Wed Feb 18 11:46:16 2015 +0100 +++ b/graal/com.oracle.graal.lir/src/com/oracle/graal/lir/LIRIntrospection.java Wed Feb 18 12:10:04 2015 +0100 @@ -35,7 +35,7 @@ import com.oracle.graal.lir.LIRInstruction.OperandFlag; import com.oracle.graal.lir.LIRInstruction.OperandMode; -abstract class LIRIntrospection extends FieldIntrospection { +abstract class LIRIntrospection extends FieldIntrospection { private static final Class VALUE_CLASS = Value.class; private static final Class CONSTANT_CLASS = JavaConstant.class; @@ -44,7 +44,7 @@ private static final Class STACK_SLOT_CLASS = StackSlot.class; private static final Class VALUE_ARRAY_CLASS = Value[].class; - public LIRIntrospection(Class clazz) { + public LIRIntrospection(Class clazz) { super(clazz); }