Commit 89af9c2d authored by Robert Bradshaw's avatar Robert Bradshaw

Fix C++ iteration inference.

parent ad0a4bf8
...@@ -1998,6 +1998,9 @@ class IteratorNode(ExprNode): ...@@ -1998,6 +1998,9 @@ class IteratorNode(ExprNode):
PyrexTypes.CFuncTypeArg("it", PyrexTypes.py_object_type, None), PyrexTypes.CFuncTypeArg("it", PyrexTypes.py_object_type, None),
])) ]))
def type_dependencies(self, env):
return self.sequence.type_dependencies(env)
def infer_type(self, env): def infer_type(self, env):
sequence_type = self.sequence.infer_type(env) sequence_type = self.sequence.infer_type(env)
if (sequence_type.is_array or sequence_type.is_ptr) and \ if (sequence_type.is_array or sequence_type.is_ptr) and \
...@@ -2205,6 +2208,9 @@ class NextNode(AtomicExprNode): ...@@ -2205,6 +2208,9 @@ class NextNode(AtomicExprNode):
self.pos = iterator.pos self.pos = iterator.pos
self.iterator = iterator self.iterator = iterator
def type_dependencies(self, env):
return self.iterator.type_dependencies(env)
def infer_type(self, env, iterator_type = None): def infer_type(self, env, iterator_type = None):
if iterator_type is None: if iterator_type is None:
iterator_type = self.iterator.infer_type(env) iterator_type = self.iterator.infer_type(env)
......
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