Commit 361b5d08 authored by Robert Bradshaw's avatar Robert Bradshaw

More loop type inference fixes.

parent 066c0e1f
...@@ -2010,6 +2010,9 @@ class IteratorNode(ExprNode): ...@@ -2010,6 +2010,9 @@ class IteratorNode(ExprNode):
begin = sequence_type.scope.lookup("begin") begin = sequence_type.scope.lookup("begin")
if begin is not None: if begin is not None:
return begin.type.base_type.return_type return begin.type.base_type.return_type
elif sequence_type.is_pyobject:
return sequence_type
else:
return py_object_type return py_object_type
def analyse_cpp_types(self, env): def analyse_cpp_types(self, env):
...@@ -2222,7 +2225,11 @@ class NextNode(AtomicExprNode): ...@@ -2222,7 +2225,11 @@ class NextNode(AtomicExprNode):
item_type = item_type.ref_base_type item_type = item_type.ref_base_type
return item_type return item_type
else: else:
return py_object_type # Avoid duplication of complicated logic.
fake_index_node = IndexNode(self.pos,
base=self.iterator,
index=IntNode(self.pos, value='0'))
return fake_index_node.infer_type(env)
def analyse_types(self, env): def analyse_types(self, env):
self.type = self.infer_type(env, self.iterator.type) self.type = self.infer_type(env, self.iterator.type)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment