Commit 967f8db2 authored by Stefan Behnel's avatar Stefan Behnel

merged in latest cython-devel

parents 16fb7e25 8be7e855
...@@ -5624,7 +5624,7 @@ class CmpNode(object): ...@@ -5624,7 +5624,7 @@ class CmpNode(object):
# Mixin class containing code common to PrimaryCmpNodes # Mixin class containing code common to PrimaryCmpNodes
# and CascadedCmpNodes. # and CascadedCmpNodes.
def infer_types(self, env): def infer_type(self, env):
# TODO: Actually implement this (after merging with -unstable). # TODO: Actually implement this (after merging with -unstable).
return py_object_type return py_object_type
......
...@@ -21,10 +21,10 @@ annotate = 0 ...@@ -21,10 +21,10 @@ annotate = 0
# This will convert statements of the form "for i in range(...)" # This will convert statements of the form "for i in range(...)"
# to "for i from ..." when i is a cdef'd integer type, and the direction # to "for i from ..." when i is a cdef'd integer type, and the direction
# (i.e. sign of step) can be determined. # (i.e. sign of step) can be determined.
# WARNING: This may change the symantics if the range causes assignment to # WARNING: This may change the semantics if the range causes assignment to
# i to overflow. Specifically, if this option is set, an error will be # i to overflow. Specifically, if this option is set, an error will be
# raised before the loop is entered, wheras without this option the loop # raised before the loop is entered, wheras without this option the loop
# will execute util a overflowing value is encountered. # will execute until an overflowing value is encountered.
convert_range = 1 convert_range = 1
# Enable this to allow one to write your_module.foo = ... to overwrite the # Enable this to allow one to write your_module.foo = ... to overwrite the
......
...@@ -673,7 +673,7 @@ def p_opt_string_literal(s): ...@@ -673,7 +673,7 @@ def p_opt_string_literal(s):
def p_string_literal(s, kind_override=None): def p_string_literal(s, kind_override=None):
# A single string or char literal. # A single string or char literal.
# Returns (kind, value) where kind in ('b', 'c', 'u') # Returns (kind, value) where kind in ('b', 'c', 'u', '')
# s.sy == 'BEGIN_STRING' # s.sy == 'BEGIN_STRING'
pos = s.position() pos = s.position()
is_raw = 0 is_raw = 0
......
...@@ -70,7 +70,15 @@ class MarkAssignments(CythonTransform): ...@@ -70,7 +70,15 @@ class MarkAssignments(CythonTransform):
sequence.args[0], sequence.args[0],
sequence.args[2])) sequence.args[2]))
if not is_special: if not is_special:
self.mark_assignment(node.target, object_expr) # A for-loop basically translates to subsequent calls to
# __getitem__(), so using an IndexNode here allows us to
# naturally infer the base type of pointers, C arrays,
# Python strings, etc., while correctly falling back to an
# object type when the base type cannot be handled.
self.mark_assignment(node.target, ExprNodes.IndexNode(
node.pos,
base = sequence,
index = ExprNodes.IntNode(node.pos, value = '0')))
self.visitchildren(node) self.visitchildren(node)
return node return node
......
...@@ -5,12 +5,12 @@ a ...@@ -5,12 +5,12 @@ a
# Indirectly makes sure the cleanup happens correctly on breaking. # Indirectly makes sure the cleanup happens correctly on breaking.
def foo(): def foo():
for x in u"abc": for x in "abc":
try: try:
x() x()
except: except:
break break
for x in u"abc": for x in "abc":
try: try:
x() x()
except: except:
......
...@@ -187,6 +187,46 @@ def loop(): ...@@ -187,6 +187,46 @@ def loop():
pass pass
assert typeof(a) == "long" assert typeof(a) == "long"
def loop_over_charptr():
"""
>>> print( loop_over_charptr() )
char
"""
cdef char* char_ptr_string = 'abcdefg'
for c in char_ptr_string:
pass
return typeof(c)
def loop_over_bytes():
"""
>>> print( loop_over_bytes() )
Python object
"""
cdef bytes bytes_string = b'abcdefg'
for c in bytes_string:
pass
return typeof(c)
def loop_over_unicode():
"""
>>> print( loop_over_unicode() )
Py_UNICODE
"""
cdef unicode ustring = u'abcdefg'
for uchar in ustring:
pass
return typeof(uchar)
def loop_over_int_array():
"""
>>> print( loop_over_int_array() )
int
"""
cdef int[10] int_array
for i in int_array:
pass
return typeof(i)
cdef unicode retu(): cdef unicode retu():
return u"12345" return u"12345"
......
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