|
40 | 40 | */
|
41 | 41 | package com.oracle.graal.python.builtins.objects.iterator;
|
42 | 42 |
|
| 43 | +import static com.oracle.graal.python.builtins.PythonBuiltinClassType.PIterator; |
43 | 44 | import static com.oracle.graal.python.builtins.PythonBuiltinClassType.TypeError;
|
44 | 45 | import static com.oracle.graal.python.nodes.SpecialMethodNames.__LENGTH_HINT__;
|
45 | 46 | import static com.oracle.graal.python.nodes.SpecialMethodNames.__LEN__;
|
46 | 47 |
|
| 48 | +import java.util.ArrayList; |
| 49 | +import java.util.List; |
| 50 | + |
47 | 51 | import com.oracle.graal.python.builtins.objects.PNone;
|
48 | 52 | import com.oracle.graal.python.builtins.objects.PNotImplemented;
|
49 | 53 | import com.oracle.graal.python.builtins.objects.common.SequenceNodes.GetSequenceStorageNode;
|
50 | 54 | import com.oracle.graal.python.builtins.objects.common.SequenceStorageNodes;
|
| 55 | +import com.oracle.graal.python.builtins.objects.iterator.IteratorNodesFactory.GetInternalIteratorSequenceStorageNodeGen; |
| 56 | +import com.oracle.graal.python.builtins.objects.list.PList; |
51 | 57 | import com.oracle.graal.python.builtins.objects.str.PString;
|
| 58 | +import com.oracle.graal.python.builtins.objects.tuple.PTuple; |
52 | 59 | import com.oracle.graal.python.builtins.objects.type.SpecialMethodSlot;
|
53 | 60 | import com.oracle.graal.python.lib.PyIndexCheckNode;
|
54 | 61 | import com.oracle.graal.python.lib.PyNumberAsSizeNode;
|
|
74 | 81 | import com.oracle.truffle.api.CompilerDirectives;
|
75 | 82 | import com.oracle.truffle.api.CompilerDirectives.TruffleBoundary;
|
76 | 83 | import com.oracle.truffle.api.dsl.Cached;
|
| 84 | +import com.oracle.truffle.api.dsl.Fallback; |
77 | 85 | import com.oracle.truffle.api.dsl.GenerateNodeFactory;
|
78 | 86 | import com.oracle.truffle.api.dsl.GenerateUncached;
|
79 | 87 | import com.oracle.truffle.api.dsl.ImportStatic;
|
|
85 | 93 | import com.oracle.truffle.api.nodes.Node;
|
86 | 94 | import com.oracle.truffle.api.profiles.ConditionProfile;
|
87 | 95 | import com.oracle.truffle.api.profiles.LoopConditionProfile;
|
88 |
| -import java.util.ArrayList; |
89 |
| -import java.util.List; |
90 | 96 |
|
91 | 97 | public abstract class IteratorNodes {
|
92 | 98 |
|
@@ -181,6 +187,102 @@ int length(VirtualFrame frame, Object iterable,
|
181 | 187 | }
|
182 | 188 | }
|
183 | 189 |
|
| 190 | + @ImportStatic(PGuards.class) |
| 191 | + public abstract static class GetInternalIteratorSequenceStorage extends Node { |
| 192 | + public static GetInternalIteratorSequenceStorage getUncached() { |
| 193 | + return GetInternalIteratorSequenceStorageNodeGen.getUncached(); |
| 194 | + } |
| 195 | + |
| 196 | + /** |
| 197 | + * The argument must be a builtin iterator, which points to the first element of the |
| 198 | + * internal sequence storage. Returns {@code null} if the sequence storage is not available |
| 199 | + * or if the iterator is not pointing to the first item in the storage. |
| 200 | + */ |
| 201 | + public final SequenceStorage execute(PBuiltinIterator iterator) { |
| 202 | + assert GetClassNode.getUncached().execute(iterator) == PIterator; |
| 203 | + assert iterator.index == 0; |
| 204 | + return executeInternal(iterator); |
| 205 | + } |
| 206 | + |
| 207 | + protected abstract SequenceStorage executeInternal(PBuiltinIterator iterator); |
| 208 | + |
| 209 | + @Specialization(guards = "isList(it.sequence)") |
| 210 | + static SequenceStorage doSequenceList(PSequenceIterator it) { |
| 211 | + return ((PList) it.sequence).getSequenceStorage(); |
| 212 | + } |
| 213 | + |
| 214 | + @Specialization |
| 215 | + static SequenceStorage doSequenceLong(PLongSequenceIterator it) { |
| 216 | + return it.sequence; |
| 217 | + } |
| 218 | + |
| 219 | + @Specialization |
| 220 | + static SequenceStorage doSequenceDouble(PDoubleSequenceIterator it) { |
| 221 | + return it.sequence; |
| 222 | + } |
| 223 | + |
| 224 | + @Specialization |
| 225 | + static SequenceStorage doSequenceObj(PObjectSequenceIterator it) { |
| 226 | + return it.sequence; |
| 227 | + } |
| 228 | + |
| 229 | + @Specialization |
| 230 | + static SequenceStorage doSequenceIntSeq(PIntegerSequenceIterator it) { |
| 231 | + return it.sequence; |
| 232 | + } |
| 233 | + |
| 234 | + @Specialization(guards = "isPTuple(it.sequence)") |
| 235 | + static SequenceStorage doSequenceTuple(PSequenceIterator it) { |
| 236 | + return ((PTuple) it.sequence).getSequenceStorage(); |
| 237 | + } |
| 238 | + |
| 239 | + @Fallback |
| 240 | + static SequenceStorage doOthers(PBuiltinIterator it) { |
| 241 | + return null; |
| 242 | + } |
| 243 | + } |
| 244 | + |
| 245 | + @ImportStatic(PGuards.class) |
| 246 | + public abstract static class BuiltinIteratorLengthHint extends Node { |
| 247 | + @Child GetInternalIteratorSequenceStorage getSeqStorage = GetInternalIteratorSequenceStorageNodeGen.create(); |
| 248 | + private final ConditionProfile noStorageProfile = ConditionProfile.createBinaryProfile(); |
| 249 | + |
| 250 | + /** |
| 251 | + * The argument must be a builtin iterator. Returns {@code -1} if the length hint is not |
| 252 | + * available. |
| 253 | + */ |
| 254 | + public final int execute(PBuiltinIterator iterator) { |
| 255 | + assert GetClassNode.getUncached().execute(iterator) == PIterator; |
| 256 | + SequenceStorage result = getSeqStorage.execute(iterator); |
| 257 | + if (noStorageProfile.profile(result != null)) { |
| 258 | + return result.length(); |
| 259 | + } |
| 260 | + return executeInternal(iterator); |
| 261 | + } |
| 262 | + |
| 263 | + protected abstract int executeInternal(PBuiltinIterator iterator); |
| 264 | + |
| 265 | + @Specialization |
| 266 | + static int doString(PStringIterator it) { |
| 267 | + return it.value.length(); |
| 268 | + } |
| 269 | + |
| 270 | + @Specialization |
| 271 | + static int doSequenceArr(PArrayIterator it) { |
| 272 | + return it.array.getLength(); |
| 273 | + } |
| 274 | + |
| 275 | + @Specialization |
| 276 | + static int doSequenceIntRange(PIntRangeIterator it) { |
| 277 | + return it.getLength(); |
| 278 | + } |
| 279 | + |
| 280 | + @Fallback |
| 281 | + static int doOthers(PBuiltinIterator it) { |
| 282 | + return -1; |
| 283 | + } |
| 284 | + } |
| 285 | + |
184 | 286 | @GenerateUncached
|
185 | 287 | public abstract static class IsIteratorObjectNode extends Node {
|
186 | 288 |
|
|
0 commit comments