Fix warnings in lang-plan-a

Removes all Xlint skips in lang-plan-a. Warnings were just some extra
casts which were removed, some raw types which we just needed to <?>, and
a couple of unchecked casts in data that we know to be Map<String, Object>
because that structure is super-ultra-common in scripts.
This commit is contained in:
Nik Everett 2016-01-18 15:25:56 -05:00
parent 3be12ed9fd
commit 08ca9d7645
4 changed files with 41 additions and 42 deletions

View File

@ -35,9 +35,6 @@ dependencyLicenses {
mapping from: /asm-.*/, to: 'asm' mapping from: /asm-.*/, to: 'asm'
} }
compileJava.options.compilerArgs << '-Xlint:-cast,-rawtypes'
compileTestJava.options.compilerArgs << '-Xlint:-unchecked'
// regeneration logic, comes in via ant right now // regeneration logic, comes in via ant right now
// don't port it to gradle, it works fine. // don't port it to gradle, it works fine.

View File

@ -778,7 +778,7 @@ class Definition {
addMethod("Def", "DefToLong", null, true, longobjType, new Type[] {defType}, null, null); addMethod("Def", "DefToLong", null, true, longobjType, new Type[] {defType}, null, null);
addMethod("Def", "DefToFloat", null, true, floatobjType, new Type[] {defType}, null, null); addMethod("Def", "DefToFloat", null, true, floatobjType, new Type[] {defType}, null, null);
addMethod("Def", "DefToDouble", null, true, doubleobjType, new Type[] {defType}, null, null); addMethod("Def", "DefToDouble", null, true, doubleobjType, new Type[] {defType}, null, null);
addMethod("List", "addLast", "add", false, booleanType, new Type[] {objectType}, null, new Type[] {defType}); addMethod("List", "addLast", "add", false, booleanType, new Type[] {objectType}, null, new Type[] {defType});
addMethod("List", "add", null, false, voidType, new Type[] {intType, objectType}, null, new Type[] {intType, defType}); addMethod("List", "add", null, false, voidType, new Type[] {intType, objectType}, null, new Type[] {intType, defType});
addMethod("List", "get", null, false, objectType, new Type[] {intType}, defType, null); addMethod("List", "get", null, false, objectType, new Type[] {intType}, defType, null);
@ -984,7 +984,7 @@ class Definition {
addTransform(defType, longobjType, "Def", "DefToLong", true); addTransform(defType, longobjType, "Def", "DefToLong", true);
addTransform(defType, floatobjType, "Def", "DefToFloat", true); addTransform(defType, floatobjType, "Def", "DefToFloat", true);
addTransform(defType, doubleobjType, "Def", "DefToDouble", true); addTransform(defType, doubleobjType, "Def", "DefToDouble", true);
addTransform(numberType, booleanType, "Utility", "NumberToboolean", true); addTransform(numberType, booleanType, "Utility", "NumberToboolean", true);
addTransform(numberType, byteType, "Number", "byteValue", false); addTransform(numberType, byteType, "Number", "byteValue", false);
addTransform(numberType, shortType, "Number", "shortValue", false); addTransform(numberType, shortType, "Number", "shortValue", false);
@ -1255,7 +1255,7 @@ class Definition {
" [" + name + "] within the same struct [" + owner.name + "]."); " [" + name + "] within the same struct [" + owner.name + "].");
} }
final Class[] classes = new Class[args.length]; final Class<?>[] classes = new Class<?>[args.length];
for (int count = 0; count < classes.length; ++count) { for (int count = 0; count < classes.length; ++count) {
if (genargs != null) { if (genargs != null) {
@ -1343,7 +1343,7 @@ class Definition {
" [" + args.length + "] within the struct [" + owner.name + "]."); " [" + args.length + "] within the struct [" + owner.name + "].");
} }
final Class[] classes = new Class[args.length]; final Class<?>[] classes = new Class<?>[args.length];
for (int count = 0; count < classes.length; ++count) { for (int count = 0; count < classes.length; ++count) {
if (genargs != null) { if (genargs != null) {

View File

@ -157,7 +157,7 @@ public class Utility {
} }
public static Character byteToCharacter(final byte value) { public static Character byteToCharacter(final byte value) {
return (char)(byte)value; return (char)value;
} }
public static Integer byteToInteger(final byte value) { public static Integer byteToInteger(final byte value) {
@ -193,7 +193,7 @@ public class Utility {
} }
public static Character shortToCharacter(final short value) { public static Character shortToCharacter(final short value) {
return (char)(short)value; return (char)value;
} }
public static Integer shortToInteger(final short value) { public static Integer shortToInteger(final short value) {
@ -211,11 +211,11 @@ public class Utility {
public static Double shortToDouble(final short value) { public static Double shortToDouble(final short value) {
return (double)value; return (double)value;
} }
public static boolean ShortToboolean(final Short value) { public static boolean ShortToboolean(final Short value) {
return value != 0; return value != 0;
} }
public static char ShortTochar(final Short value) { public static char ShortTochar(final Short value) {
return (char)value.shortValue(); return (char)value.shortValue();
} }
@ -261,19 +261,19 @@ public class Utility {
} }
public static int CharacterToint(final Character value) { public static int CharacterToint(final Character value) {
return (int)value; return value;
} }
public static long CharacterTolong(final Character value) { public static long CharacterTolong(final Character value) {
return (long)value; return value;
} }
public static float CharacterTofloat(final Character value) { public static float CharacterTofloat(final Character value) {
return (float)value; return value;
} }
public static double CharacterTodouble(final Character value) { public static double CharacterTodouble(final Character value) {
return (double)value; return value;
} }
public static Boolean CharacterToBoolean(final Character value) { public static Boolean CharacterToBoolean(final Character value) {
@ -317,7 +317,7 @@ public class Utility {
} }
public static Character intToCharacter(final int value) { public static Character intToCharacter(final int value) {
return (char)(int)value; return (char)value;
} }
public static Long intToLong(final int value) { public static Long intToLong(final int value) {
@ -331,7 +331,7 @@ public class Utility {
public static Double intToDouble(final int value) { public static Double intToDouble(final int value) {
return (double)value; return (double)value;
} }
public static boolean IntegerToboolean(final Integer value) { public static boolean IntegerToboolean(final Integer value) {
return value != 0; return value != 0;
} }
@ -353,7 +353,7 @@ public class Utility {
} }
public static Character longToCharacter(final long value) { public static Character longToCharacter(final long value) {
return (char)(long)value; return (char)value;
} }
public static Integer longToInteger(final long value) { public static Integer longToInteger(final long value) {
@ -367,7 +367,7 @@ public class Utility {
public static Double longToDouble(final long value) { public static Double longToDouble(final long value) {
return (double)value; return (double)value;
} }
public static boolean LongToboolean(final Long value) { public static boolean LongToboolean(final Long value) {
return value != 0; return value != 0;
} }
@ -389,7 +389,7 @@ public class Utility {
} }
public static Character floatToCharacter(final float value) { public static Character floatToCharacter(final float value) {
return (char)(float)value; return (char)value;
} }
public static Integer floatToInteger(final float value) { public static Integer floatToInteger(final float value) {
@ -403,11 +403,11 @@ public class Utility {
public static Double floatToDouble(final float value) { public static Double floatToDouble(final float value) {
return (double)value; return (double)value;
} }
public static boolean FloatToboolean(final Float value) { public static boolean FloatToboolean(final Float value) {
return value != 0; return value != 0;
} }
public static char FloatTochar(final Float value) { public static char FloatTochar(final Float value) {
return (char)value.floatValue(); return (char)value.floatValue();
} }
@ -425,7 +425,7 @@ public class Utility {
} }
public static Character doubleToCharacter(final double value) { public static Character doubleToCharacter(final double value) {
return (char)(double)value; return (char)value;
} }
public static Integer doubleToInteger(final double value) { public static Integer doubleToInteger(final double value) {
@ -435,23 +435,23 @@ public class Utility {
public static Long doubleToLong(final double value) { public static Long doubleToLong(final double value) {
return (long)value; return (long)value;
} }
public static Float doubleToFloat(final double value) { public static Float doubleToFloat(final double value) {
return (float)value; return (float)value;
} }
public static boolean DoubleToboolean(final Double value) { public static boolean DoubleToboolean(final Double value) {
return value != 0; return value != 0;
} }
public static char DoubleTochar(final Double value) { public static char DoubleTochar(final Double value) {
return (char)value.doubleValue(); return (char)value.doubleValue();
} }
// although divide by zero is guaranteed, the special overflow case is not caught. // although divide by zero is guaranteed, the special overflow case is not caught.
// its not needed for remainder because it is not possible there. // its not needed for remainder because it is not possible there.
// see https://docs.oracle.com/javase/specs/jls/se8/html/jls-15.html#jls-15.17.2 // see https://docs.oracle.com/javase/specs/jls/se8/html/jls-15.html#jls-15.17.2
/** /**
* Integer divide without overflow * Integer divide without overflow
* @throws ArithmeticException on overflow or divide-by-zero * @throws ArithmeticException on overflow or divide-by-zero
@ -462,7 +462,7 @@ public class Utility {
} }
return x / y; return x / y;
} }
/** /**
* Long divide without overflow * Long divide without overflow
* @throws ArithmeticException on overflow or divide-by-zero * @throws ArithmeticException on overflow or divide-by-zero
@ -667,7 +667,7 @@ public class Utility {
} }
return z; return z;
} }
/** /**
* Checks for NaN, result is NaN but operands are finite * Checks for NaN, result is NaN but operands are finite
* @throws ArithmeticException if overflow occurred * @throws ArithmeticException if overflow occurred
@ -680,7 +680,7 @@ public class Utility {
} }
return z; return z;
} }
/** /**
* Checks for NaN, result is infinite but operands are finite * Checks for NaN, result is infinite but operands are finite
* @throws ArithmeticException if overflow occurred * @throws ArithmeticException if overflow occurred
@ -693,7 +693,7 @@ public class Utility {
} }
return z; return z;
} }
/** /**
* Checks for NaN, result is NaN but operands are finite * Checks for NaN, result is NaN but operands are finite
* @throws ArithmeticException if overflow occurred * @throws ArithmeticException if overflow occurred
@ -706,7 +706,7 @@ public class Utility {
} }
return z; return z;
} }
/** /**
* Adds two floats but throws {@code ArithmeticException} * Adds two floats but throws {@code ArithmeticException}
* if the result overflows. * if the result overflows.
@ -714,7 +714,7 @@ public class Utility {
public static float addWithoutOverflow(float x, float y) { public static float addWithoutOverflow(float x, float y) {
return checkInfFloat(x, y, x + y); return checkInfFloat(x, y, x + y);
} }
/** /**
* Adds two doubles but throws {@code ArithmeticException} * Adds two doubles but throws {@code ArithmeticException}
* if the result overflows. * if the result overflows.
@ -722,7 +722,7 @@ public class Utility {
public static double addWithoutOverflow(double x, double y) { public static double addWithoutOverflow(double x, double y) {
return checkInfDouble(x, y, x + y); return checkInfDouble(x, y, x + y);
} }
/** /**
* Subtracts two floats but throws {@code ArithmeticException} * Subtracts two floats but throws {@code ArithmeticException}
* if the result overflows. * if the result overflows.
@ -730,7 +730,7 @@ public class Utility {
public static float subtractWithoutOverflow(float x, float y) { public static float subtractWithoutOverflow(float x, float y) {
return checkInfFloat(x, y, x - y); return checkInfFloat(x, y, x - y);
} }
/** /**
* Subtracts two doubles but throws {@code ArithmeticException} * Subtracts two doubles but throws {@code ArithmeticException}
* if the result overflows. * if the result overflows.
@ -738,7 +738,7 @@ public class Utility {
public static double subtractWithoutOverflow(double x, double y) { public static double subtractWithoutOverflow(double x, double y) {
return checkInfDouble(x, y , x - y); return checkInfDouble(x, y , x - y);
} }
/** /**
* Multiplies two floats but throws {@code ArithmeticException} * Multiplies two floats but throws {@code ArithmeticException}
* if the result overflows. * if the result overflows.
@ -746,7 +746,7 @@ public class Utility {
public static float multiplyWithoutOverflow(float x, float y) { public static float multiplyWithoutOverflow(float x, float y) {
return checkInfFloat(x, y, x * y); return checkInfFloat(x, y, x * y);
} }
/** /**
* Multiplies two doubles but throws {@code ArithmeticException} * Multiplies two doubles but throws {@code ArithmeticException}
* if the result overflows. * if the result overflows.
@ -754,7 +754,7 @@ public class Utility {
public static double multiplyWithoutOverflow(double x, double y) { public static double multiplyWithoutOverflow(double x, double y) {
return checkInfDouble(x, y, x * y); return checkInfDouble(x, y, x * y);
} }
/** /**
* Divides two floats but throws {@code ArithmeticException} * Divides two floats but throws {@code ArithmeticException}
* if the result overflows, or would create NaN from finite * if the result overflows, or would create NaN from finite
@ -763,7 +763,7 @@ public class Utility {
public static float divideWithoutOverflow(float x, float y) { public static float divideWithoutOverflow(float x, float y) {
return checkNaNFloat(x, y, checkInfFloat(x, y, x / y)); return checkNaNFloat(x, y, checkInfFloat(x, y, x / y));
} }
/** /**
* Divides two doubles but throws {@code ArithmeticException} * Divides two doubles but throws {@code ArithmeticException}
* if the result overflows, or would create NaN from finite * if the result overflows, or would create NaN from finite
@ -772,7 +772,7 @@ public class Utility {
public static double divideWithoutOverflow(double x, double y) { public static double divideWithoutOverflow(double x, double y) {
return checkNaNDouble(x, y, checkInfDouble(x, y, x / y)); return checkNaNDouble(x, y, checkInfDouble(x, y, x / y));
} }
/** /**
* Takes remainder two floats but throws {@code ArithmeticException} * Takes remainder two floats but throws {@code ArithmeticException}
* if the result would create NaN from finite inputs ({@code y == 0}) * if the result would create NaN from finite inputs ({@code y == 0})
@ -780,7 +780,7 @@ public class Utility {
public static float remainderWithoutOverflow(float x, float y) { public static float remainderWithoutOverflow(float x, float y) {
return checkNaNFloat(x, y, x % y); return checkNaNFloat(x, y, x % y);
} }
/** /**
* Divides two doubles but throws {@code ArithmeticException} * Divides two doubles but throws {@code ArithmeticException}
* if the result would create NaN from finite inputs ({@code y == 0}) * if the result would create NaN from finite inputs ({@code y == 0})

View File

@ -35,6 +35,7 @@ public class ScriptEngineTests extends ScriptTestCase {
assertEquals(3, ((Number)value).intValue()); assertEquals(3, ((Number)value).intValue());
} }
@SuppressWarnings("unchecked") // We know its Map<String, Object> because we put them there in the test
public void testMapAccess() { public void testMapAccess() {
Map<String, Object> vars = new HashMap<>(); Map<String, Object> vars = new HashMap<>();
Map<String, Object> obj2 = new HashMap<>(); Map<String, Object> obj2 = new HashMap<>();
@ -54,6 +55,7 @@ public class ScriptEngineTests extends ScriptTestCase {
assertEquals("2", value); assertEquals("2", value);
} }
@SuppressWarnings("unchecked") // We know its Map<String, Object> because we put them there ourselves
public void testAccessListInScript() { public void testAccessListInScript() {
Map<String, Object> vars = new HashMap<>(); Map<String, Object> vars = new HashMap<>();
Map<String, Object> obj2 = new HashMap<>(); Map<String, Object> obj2 = new HashMap<>();