Add test cases for primitive arrays

This commit is contained in:
Alexey Andreev 2015-09-11 19:32:03 +03:00
parent f620f9513e
commit 0b66d4c799
3 changed files with 175 additions and 15 deletions

View File

@ -704,6 +704,7 @@ class JavascriptNativeProcessor {
insn.getArguments().add(var); insn.getArguments().add(var);
insn.setReceiver(result); insn.setReceiver(result);
replacement.add(insn);
return result; return result;
} }
@ -725,6 +726,7 @@ class JavascriptNativeProcessor {
} }
insn.setReceiver(function); insn.setReceiver(function);
replacement.add(insn);
while (--degree > 1) { while (--degree > 1) {
type = ValueType.arrayOf(type); type = ValueType.arrayOf(type);
@ -744,9 +746,28 @@ class JavascriptNativeProcessor {
insn.getArguments().add(function); insn.getArguments().add(function);
function = program.createVariable(); function = program.createVariable();
insn.setReceiver(function); insn.setReceiver(function);
replacement.add(insn);
} }
return null; Variable cls = program.createVariable();
ClassConstantInstruction clsInsn = new ClassConstantInstruction();
clsInsn.setConstant(ValueType.arrayOf(type));
clsInsn.setLocation(location.getSourceLocation());
clsInsn.setReceiver(cls);
replacement.add(clsInsn);
insn = new InvokeInstruction();
insn.setMethod(new MethodReference(JS.class, "unmapArray", Class.class, JSArrayReader.class, Function.class,
Object[].class));
insn.getArguments().add(cls);
insn.getArguments().add(var);
insn.getArguments().add(function);
insn.setReceiver(var);
insn.setType(InvocationType.SPECIAL);
insn.setLocation(location.getSourceLocation());
replacement.add(insn);
return var;
} }
private MethodReference singleDimensionArrayUnwrapper(ValueType itemType) { private MethodReference singleDimensionArrayUnwrapper(ValueType itemType) {
@ -779,26 +800,26 @@ class JavascriptNativeProcessor {
if (itemType instanceof ValueType.Primitive) { if (itemType instanceof ValueType.Primitive) {
switch (((ValueType.Primitive) itemType).getKind()) { switch (((ValueType.Primitive) itemType).getKind()) {
case BOOLEAN: case BOOLEAN:
return new MethodReference(JS.class, "booleanArrayUnwrapper", Function.class, Function.class); return new MethodReference(JS.class, "booleanArrayUnwrapper", Function.class);
case BYTE: case BYTE:
return new MethodReference(JS.class, "byteArrayUnwrapper", Function.class, Function.class); return new MethodReference(JS.class, "byteArrayUnwrapper", Function.class);
case SHORT: case SHORT:
return new MethodReference(JS.class, "shortArrayUnwrapper", Function.class, Function.class); return new MethodReference(JS.class, "shortArrayUnwrapper", Function.class);
case CHARACTER: case CHARACTER:
return new MethodReference(JS.class, "charArrayUnwrapper", Function.class, Function.class); return new MethodReference(JS.class, "charArrayUnwrapper", Function.class);
case INTEGER: case INTEGER:
return new MethodReference(JS.class, "intArrayUnwrapper", Function.class, Function.class); return new MethodReference(JS.class, "intArrayUnwrapper", Function.class);
case FLOAT: case FLOAT:
return new MethodReference(JS.class, "floatArrayUnwrapper", Function.class, Function.class); return new MethodReference(JS.class, "floatArrayUnwrapper", Function.class);
case DOUBLE: case DOUBLE:
return new MethodReference(JS.class, "doubleArrayUnwrapper", Function.class, Function.class); return new MethodReference(JS.class, "doubleArrayUnwrapper", Function.class);
default: default:
break; break;
} }
} else if (itemType.isObject(String.class)) { } else if (itemType.isObject(String.class)) {
return new MethodReference(JS.class, "stringArrayUnwrapper", Function.class, Function.class); return new MethodReference(JS.class, "stringArrayUnwrapper", Function.class);
} }
return new MethodReference(JS.class, "arrayUnwrapper", Class.class, Function.class, Function.class); return new MethodReference(JS.class, "arrayUnwrapper", Class.class, Function.class);
} }
private Variable unwrap(Variable var, String methodName, ValueType argType, ValueType resultType, private Variable unwrap(Variable var, String methodName, ValueType argType, ValueType resultType,
@ -946,7 +967,11 @@ class JavascriptNativeProcessor {
private ValueType getWrappedType(ValueType type) { private ValueType getWrappedType(ValueType type) {
if (type instanceof ValueType.Array) { if (type instanceof ValueType.Array) {
ValueType itemType = ((ValueType.Array) type).getItemType(); ValueType itemType = ((ValueType.Array) type).getItemType();
if (itemType instanceof ValueType.Array) {
return ValueType.parse(Object[].class);
} else {
return ValueType.arrayOf(getWrappedType(itemType)); return ValueType.arrayOf(getWrappedType(itemType));
}
} else if (type instanceof ValueType.Object) { } else if (type instanceof ValueType.Object) {
if (type.isObject(String.class)) { if (type.isObject(String.class)) {
return type; return type;

View File

@ -46,13 +46,19 @@ public class ConversionTest {
} }
@Test @Test
public void convertsArraysToJava() { public void convertsPrimitiveArraysToJavaScript() {
assertEquals("true:2:3:64:4:5.5:6.5:foo", combinePrimitiveArrays(new boolean[] { true }, new byte[] { 2 },
new short[] { 3 }, new char[] { '@' }, new int[] { 4 }, new float[] { 5.5F }, new double[] { 6.5 },
new String[] { "foo" }));
}
@Test
public void convertsPrimitiveArraysToJava() {
PrimitiveArrays arrays = getPrimitiveArrays(); PrimitiveArrays arrays = getPrimitiveArrays();
boolean[] booleanArray = arrays.getA(); boolean[] booleanArray = arrays.getA();
assertEquals(4, booleanArray.length); assertEquals(1, booleanArray.length);
assertTrue(booleanArray[0]); assertTrue(booleanArray[0]);
assertFalse(booleanArray[1]);
assertArrayEquals(new byte[] { 2 }, arrays.getB()); assertArrayEquals(new byte[] { 2 }, arrays.getB());
assertArrayEquals(new short[] { 3 }, arrays.getC()); assertArrayEquals(new short[] { 3 }, arrays.getC());
@ -63,6 +69,57 @@ public class ConversionTest {
assertArrayEquals(new String[] { "foo" }, arrays.getH()); assertArrayEquals(new String[] { "foo" }, arrays.getH());
} }
@Test
public void convertsPrimitiveArrays2ToJavaScript() {
assertEquals("true:2:3:64:4:5.5:6.5:foo", combinePrimitiveArrays2(new boolean[][] {{ true }},
new byte[][] {{ 2 }}, new short[][] {{ 3 }}, new char[][] {{ '@' }}, new int[][] {{ 4 }},
new float[][] {{ 5.5F }}, new double[][] {{ 6.5 }}, new String[][] {{ "foo" }}));
}
@Test
public void convertsPrimitiveArrays2ToJava() {
PrimitiveArrays2 arrays = getPrimitiveArrays2();
boolean[][] booleanArray = arrays.getA();
assertEquals(1, booleanArray.length);
assertEquals(1, booleanArray[0].length);
assertTrue(booleanArray[0][0]);
assertArrayEquals(new byte[] { 2 }, arrays.getB()[0]);
assertArrayEquals(new short[] { 3 }, arrays.getC()[0]);
assertArrayEquals(new char[] { '@' }, arrays.getD()[0]);
assertArrayEquals(new int[] { 4 }, arrays.getE()[0]);
assertArrayEquals(new float[] { 5.5F }, arrays.getF()[0], 0.01F);
assertArrayEquals(new double[] { 6.5 }, arrays.getG()[0], 0.01);
assertArrayEquals(new String[] { "foo" }, arrays.getH()[0]);
}
@Test
public void convertsPrimitiveArrays4ToJavaScript() {
assertEquals("true:2:3:64:4:5.5:6.5:foo", combinePrimitiveArrays4(new boolean[][][][] {{{{ true }}}},
new byte[][][][] {{{{ 2 }}}}, new short[][][][] {{{{ 3 }}}}, new char[][][][] {{{{ '@' }}}},
new int[][][][] {{{{ 4 }}}}, new float[][][][] {{{{ 5.5F }}}}, new double[][][][] {{{{ 6.5 }}}},
new String[][][][] {{{{ "foo" }}}}));
}
@Test
public void convertsPrimitiveArrays4ToJava() {
PrimitiveArrays4 arrays = getPrimitiveArrays4();
boolean[][][][] booleanArray = arrays.getA();
assertEquals(1, booleanArray.length);
assertEquals(1, booleanArray[0][0][0].length);
assertTrue(booleanArray[0][0][0][0]);
assertArrayEquals(new byte[] { 2 }, arrays.getB()[0][0][0]);
assertArrayEquals(new short[] { 3 }, arrays.getC()[0][0][0]);
assertArrayEquals(new char[] { '@' }, arrays.getD()[0][0][0]);
assertArrayEquals(new int[] { 4 }, arrays.getE()[0][0][0]);
assertArrayEquals(new float[] { 5.5F }, arrays.getF()[0][0][0], 0.01F);
assertArrayEquals(new double[] { 6.5 }, arrays.getG()[0][0][0], 0.01);
assertArrayEquals(new String[] { "foo" }, arrays.getH()[0][0][0]);
}
@JSBody(params = { "a", "b", "c", "d", "e", "f", "g", "h" }, script = "" @JSBody(params = { "a", "b", "c", "d", "e", "f", "g", "h" }, script = ""
+ "return '' + a + ':' + b + ':' + c + ':' + d + ':' + e + ':' + f.toFixed(1) + ':'" + "return '' + a + ':' + b + ':' + c + ':' + d + ':' + e + ':' + f.toFixed(1) + ':'"
+ "+ g.toFixed(1) + ':' + h;") + "+ g.toFixed(1) + ':' + h;")
@ -72,10 +129,37 @@ public class ConversionTest {
@JSBody(params = {}, script = "return { a : true, b : 2, c : 3, d : 64, e : 4, f : 5.5, g : 6.5, h : 'foo' };") @JSBody(params = {}, script = "return { a : true, b : 2, c : 3, d : 64, e : 4, f : 5.5, g : 6.5, h : 'foo' };")
private static native Primitives getPrimitives(); private static native Primitives getPrimitives();
@JSBody(params = { "a", "b", "c", "d", "e", "f", "g", "h" }, script = ""
+ "return '' + a[0] + ':' + b[0] + ':' + c[0] + ':' + d[0] + ':' + e[0] + ':' + f[0].toFixed(1) + ':'"
+ "+ g[0].toFixed(1) + ':' + h[0];")
private static native String combinePrimitiveArrays(boolean[] a, byte[] b, short[] c, char[] d, int[] e, float[] f,
double[] g, String[] h);
@JSBody(params = {}, script = "return { a : [true], b : [2], c : [3], d : [64], e : [4], f : [5.5], " @JSBody(params = {}, script = "return { a : [true], b : [2], c : [3], d : [64], e : [4], f : [5.5], "
+ "g : [6.5], h : ['foo'] };") + "g : [6.5], h : ['foo'] };")
private static native PrimitiveArrays getPrimitiveArrays(); private static native PrimitiveArrays getPrimitiveArrays();
@JSBody(params = { "a", "b", "c", "d", "e", "f", "g", "h" }, script = ""
+ "return '' + a[0][0] + ':' + b[0][0] + ':' + c[0][0] + ':' + d[0][0] + ':' + e[0][0] + ':' "
+ "+ f[0][0].toFixed(1) + ':' + g[0][0].toFixed(1) + ':' + h[0][0];")
private static native String combinePrimitiveArrays2(boolean[][] a, byte[][] b, short[][] c, char[][] d, int[][] e,
float[][] f, double[][] g, String[][] h);
@JSBody(params = {}, script = "return { a : [[true]], b : [[2]], c : [[3]], d : [[64]], e : [[4]], f : [[5.5]], "
+ "g : [[6.5]], h : [['foo']] };")
private static native PrimitiveArrays2 getPrimitiveArrays2();
@JSBody(params = { "a", "b", "c", "d", "e", "f", "g", "h" }, script = ""
+ "return '' + a[0][0][0][0] + ':' + b[0][0][0][0] + ':' + c[0][0][0][0] + ':' + d[0][0][0][0] + ':' "
+ "+ e[0][0][0][0] + ':' + f[0][0][0][0].toFixed(1) + ':' + g[0][0][0][0].toFixed(1) + ':' "
+ "+ h[0][0][0][0];")
private static native String combinePrimitiveArrays4(boolean[][][][] a, byte[][][][] b, short[][][][] c,
char[][][][] d, int[][][][] e, float[][][][] f, double[][][][] g, String[][][][] h);
@JSBody(params = {}, script = "return { a : [[[[true]]]], b : [[[[2]]]], c : [[[[3]]]], d : [[[[64]]]], "
+ "e : [[[[4]]]], f : [[[[5.5]]]], g : [[[[6.5]]]], h : [[[['foo']]]] };")
private static native PrimitiveArrays4 getPrimitiveArrays4();
interface Primitives extends JSObject { interface Primitives extends JSObject {
@JSProperty @JSProperty
boolean getA(); boolean getA();
@ -127,4 +211,56 @@ public class ConversionTest {
@JSProperty @JSProperty
String[] getH(); String[] getH();
} }
interface PrimitiveArrays2 extends JSObject {
@JSProperty
boolean[][] getA();
@JSProperty
byte[][] getB();
@JSProperty
short[][] getC();
@JSProperty
char[][] getD();
@JSProperty
int[][] getE();
@JSProperty
float[][] getF();
@JSProperty
double[][] getG();
@JSProperty
String[][] getH();
}
interface PrimitiveArrays4 extends JSObject {
@JSProperty
boolean[][][][] getA();
@JSProperty
byte[][][][] getB();
@JSProperty
short[][][][] getC();
@JSProperty
char[][][][] getD();
@JSProperty
int[][][][] getE();
@JSProperty
float[][][][] getF();
@JSProperty
double[][][][] getG();
@JSProperty
String[][][][] getH();
}
} }

View File

@ -81,7 +81,6 @@
</plugin> </plugin>
<plugin> <plugin>
<artifactId>maven-jar-plugin</artifactId> <artifactId>maven-jar-plugin</artifactId>
<version>2.5</version>
<executions> <executions>
<execution> <execution>
<phase>prepare-package</phase> <phase>prepare-package</phase>