|
@@ -7,10 +7,11 @@ import org.openzen.zenscript.codemodel.statement.VarStatement;
|
7
|
7
|
import org.openzen.zenscript.javabytecode.JavaLocalVariableInfo;
|
8
|
8
|
import org.openzen.zenscript.javashared.JavaClass;
|
9
|
9
|
import org.openzen.zenscript.javashared.JavaMethod;
|
|
10
|
+import org.openzen.zenscript.javashared.JavaModifiers;
|
10
|
11
|
|
11
|
12
|
import java.util.HashMap;
|
12
|
13
|
import java.util.Map;
|
13
|
|
-
|
|
14
|
+@SuppressWarnings("Duplicates")
|
14
|
15
|
public class JavaForeachWriter {
|
15
|
16
|
|
16
|
17
|
private final JavaWriter javaWriter;
|
|
@@ -19,6 +20,7 @@ public class JavaForeachWriter {
|
19
|
20
|
private final Label startLabel;
|
20
|
21
|
private final Label endLabel;
|
21
|
22
|
private final JavaStatementVisitor statementVisitor;
|
|
23
|
+ private final JavaUnboxingTypeVisitor unboxingTypeVisitor;
|
22
|
24
|
|
23
|
25
|
public JavaForeachWriter(JavaStatementVisitor statementVisitor, VarStatement[] variables, Statement content, Label start, Label end) {
|
24
|
26
|
this.statementVisitor = statementVisitor;
|
|
@@ -27,7 +29,8 @@ public class JavaForeachWriter {
|
27
|
29
|
this.content = content;
|
28
|
30
|
this.startLabel = start;
|
29
|
31
|
this.endLabel = end;
|
30
|
|
- }
|
|
32
|
+ this.unboxingTypeVisitor = new JavaUnboxingTypeVisitor(this.javaWriter);
|
|
33
|
+ }
|
31
|
34
|
|
32
|
35
|
public void visitIntRange() {
|
33
|
36
|
javaWriter.dup();
|
|
@@ -55,8 +58,7 @@ public class JavaForeachWriter {
|
55
|
58
|
}
|
56
|
59
|
|
57
|
60
|
public void visitStringCharacterIterator() {
|
58
|
|
- //TODO UNTESTED!
|
59
|
|
- javaWriter.invokeSpecial("java/lang/String", "toCharArray()", "()[C");
|
|
61
|
+ javaWriter.invokeVirtual(JavaMethod.getVirtual(JavaClass.STRING, "toCharArray", "()[C", JavaModifiers.PUBLIC));
|
60
|
62
|
handleArray(javaWriter.local(int.class), javaWriter.getLocalVariable(variables[0].variable));
|
61
|
63
|
}
|
62
|
64
|
|
|
@@ -66,12 +68,12 @@ public class JavaForeachWriter {
|
66
|
68
|
|
67
|
69
|
javaWriter.label(startLabel);
|
68
|
70
|
javaWriter.dup();
|
69
|
|
- javaWriter.dup();
|
70
|
71
|
javaWriter.arrayLength();
|
71
|
|
- javaWriter.loadInt(z);
|
72
|
|
-
|
73
|
|
- javaWriter.ifICmpLE(endLabel);
|
74
|
|
- javaWriter.loadInt(z);
|
|
72
|
+ javaWriter.loadInt(z);
|
|
73
|
+
|
|
74
|
+ javaWriter.ifICmpLE(endLabel);
|
|
75
|
+ javaWriter.dup();
|
|
76
|
+ javaWriter.loadInt(z);
|
75
|
77
|
|
76
|
78
|
|
77
|
79
|
javaWriter.arrayLoad(arrayTypeInfo.type);
|
|
@@ -85,7 +87,21 @@ public class JavaForeachWriter {
|
85
|
87
|
}
|
86
|
88
|
|
87
|
89
|
public void visitAssocKeyIterator() {
|
88
|
|
- throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
|
|
90
|
+ javaWriter.invokeInterface(JavaMethod.getVirtual(JavaClass.MAP, "keySet", "()Ljava/util/Set;", 0));
|
|
91
|
+ javaWriter.invokeInterface(JavaMethod.getVirtual(JavaClass.COLLECTION, "iterator", "()Ljava/util/Iterator;", 0));
|
|
92
|
+
|
|
93
|
+ javaWriter.label(startLabel);
|
|
94
|
+ javaWriter.dup();
|
|
95
|
+ javaWriter.invokeInterface(JavaMethod.getVirtual(JavaClass.ITERATOR, "hasNext", "()Z", 0));
|
|
96
|
+ javaWriter.ifEQ(endLabel);
|
|
97
|
+ javaWriter.dup();
|
|
98
|
+ javaWriter.invokeInterface(JavaMethod.getVirtual(JavaClass.ITERATOR, "next", "()Ljava/lang/Object;", 0));
|
|
99
|
+
|
|
100
|
+ final JavaLocalVariableInfo keyVariable = javaWriter.getLocalVariable(variables[0].variable);
|
|
101
|
+ this.downCast(0, keyVariable.type);
|
|
102
|
+ javaWriter.store(keyVariable.type, keyVariable.local);
|
|
103
|
+
|
|
104
|
+ content.accept(statementVisitor);
|
89
|
105
|
}
|
90
|
106
|
|
91
|
107
|
public void visitAssocKeyValueIterator() {
|
|
@@ -96,6 +112,7 @@ public class JavaForeachWriter {
|
96
|
112
|
javaWriter.dup();
|
97
|
113
|
javaWriter.invokeInterface(JavaMethod.getVirtual(JavaClass.ITERATOR, "hasNext", "()Z", 0));
|
98
|
114
|
javaWriter.ifEQ(endLabel);
|
|
115
|
+ javaWriter.dup();
|
99
|
116
|
javaWriter.invokeInterface(JavaMethod.getVirtual(JavaClass.ITERATOR, "next", "()Ljava/lang/Object;", 0));
|
100
|
117
|
javaWriter.checkCast(Type.getType(Map.Entry.class));
|
101
|
118
|
javaWriter.dup(false);
|
|
@@ -105,13 +122,21 @@ public class JavaForeachWriter {
|
105
|
122
|
final JavaLocalVariableInfo valueVariable = javaWriter.getLocalVariable(variables[1].variable);
|
106
|
123
|
|
107
|
124
|
javaWriter.invokeInterface(JavaMethod.getVirtual(JavaClass.fromInternalName("java/util/Map$Entry", JavaClass.Kind.INTERFACE), "getKey", "()Ljava/lang/Object;", 0));
|
|
125
|
+ this.downCast(0, keyVariable.type);
|
108
|
126
|
javaWriter.store(keyVariable.type, keyVariable.local);
|
109
|
|
-
|
|
127
|
+
|
110
|
128
|
javaWriter.invokeInterface(JavaMethod.getVirtual(JavaClass.fromInternalName("java/util/Map$Entry", JavaClass.Kind.INTERFACE), "getValue", "()Ljava/lang/Object;", 0));
|
|
129
|
+ this.downCast(1, valueVariable.type);
|
111
|
130
|
javaWriter.store(valueVariable.type, valueVariable.local);
|
|
131
|
+
|
112
|
132
|
content.accept(statementVisitor);
|
113
|
|
-
|
114
|
|
-
|
115
|
|
- //throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
|
116
|
133
|
}
|
|
134
|
+
|
|
135
|
+ private void downCast(int typeNumber, Type t) {
|
|
136
|
+ if(CompilerUtils.isPrimitive(variables[typeNumber].type.type)) {
|
|
137
|
+ variables[typeNumber].type.type.accept(variables[typeNumber].type, unboxingTypeVisitor);
|
|
138
|
+ } else {
|
|
139
|
+ javaWriter.checkCast(t);
|
|
140
|
+ }
|
|
141
|
+ }
|
117
|
142
|
}
|